Commit 9f722a52cac00ea4189c60056a84da4873b78ecf
1 parent
2d183cfc
Exists in
master
Adicionado javadoc para a classe
br.gov.frameworkdemoiselle.exception.ExceptionHandlerInterceptor
Showing
1 changed file
with
54 additions
and
1 deletions
Show diff stats
impl/core/src/main/java/br/gov/frameworkdemoiselle/exception/ExceptionHandlerInterceptor.java
... | ... | @@ -51,12 +51,65 @@ import javax.interceptor.InvocationContext; |
51 | 51 | |
52 | 52 | import org.slf4j.Logger; |
53 | 53 | |
54 | +import exception.custom.CustomException; | |
55 | + | |
54 | 56 | import br.gov.frameworkdemoiselle.DemoiselleException; |
55 | 57 | import br.gov.frameworkdemoiselle.stereotype.Controller; |
56 | 58 | import br.gov.frameworkdemoiselle.util.Beans; |
57 | 59 | import br.gov.frameworkdemoiselle.util.NameQualifier; |
58 | 60 | import br.gov.frameworkdemoiselle.util.ResourceBundle; |
59 | 61 | |
62 | +/** | |
63 | + * <p> | |
64 | + * Intercepts some thrown exceptions, and calls the appropriate method. These interceptor works only in | |
65 | + * classes annotated with <b>@Contoller</b>. Above we discribe which kind of exception is intercepted and | |
66 | + * what is an appropriate method. | |
67 | + * <p> | |
68 | + * To be interceptable, the thrown exception must be from a type which is annotated with | |
69 | + * <b>@ApplicationException</b>. | |
70 | + * <p> | |
71 | + * An appropriate method must be annotated with <b>@ExceptionHandler</b>, and receive as parameter some | |
72 | + * exception that could be thrown for it's class (which have to be annotated with <b>@ApplicationException</b>). | |
73 | + * So, when this method is called, it's receive the thrown exception as parameter. In the same class shouldn't | |
74 | + * be more than one method annotated with <b>@ExceptionHandler</b> and receiving the same type of exception. | |
75 | + * <p> | |
76 | + * <p> | |
77 | + * The examples below shows how these interceptor works: | |
78 | + * <p> | |
79 | + * | |
80 | + * <blockquote> | |
81 | + * | |
82 | + * <pre> | |
83 | + * @ApplicationException | |
84 | + * public class CustomException extends RuntimeException { | |
85 | + * } | |
86 | + * | |
87 | + * @Controller | |
88 | + * public class CustomExceptionHandler { | |
89 | + * | |
90 | + * public void throwException() { | |
91 | + * throw new CustomException(); | |
92 | + * } | |
93 | + * | |
94 | + * @ExceptionHandler | |
95 | + * public void handler(CustomException exception) { | |
96 | + * ... | |
97 | + * } | |
98 | + * | |
99 | + * } | |
100 | + * </pre> | |
101 | + * </blockquote> | |
102 | + * | |
103 | + * <p> | |
104 | + * When the method <b>throwException</b> throw a <b>CustomException</b>, once CustomException is annotated | |
105 | + * with @ApplicationException and CustomExceptionHandle is annotated with @Controller, the interceptor will | |
106 | + * looking for some method (in CustomExceptionHandle) annotated with @ExceptionHandle and that receive a | |
107 | + * CustomException as parameter to call. In the case shown, the method <b>handler</b> is called when a | |
108 | + * <b>CustomException</b> is thrown. | |
109 | + * <p> | |
110 | + * | |
111 | + * @author SERPRO | |
112 | + */ | |
60 | 113 | @Interceptor |
61 | 114 | @Controller |
62 | 115 | public class ExceptionHandlerInterceptor implements Serializable { |
... | ... | @@ -68,7 +121,7 @@ public class ExceptionHandlerInterceptor implements Serializable { |
68 | 121 | private static transient Logger logger; |
69 | 122 | |
70 | 123 | private final Map<Class<?>, Map<Class<?>, Method>> cache = new HashMap<Class<?>, Map<Class<?>, Method>>(); |
71 | - | |
124 | + | |
72 | 125 | private boolean handleException(final Exception cause, final Object target) throws Exception { |
73 | 126 | getLogger().info(getBundle().getString("handling-exception", cause.getClass().getCanonicalName())); |
74 | 127 | ... | ... |