5 changed files with 116 additions and 17 deletions
@ -0,0 +1,95 @@
@@ -0,0 +1,95 @@
|
||||
/* |
||||
* Copyright 2002-2015 the original author or authors. |
||||
* |
||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
* you may not use this file except in compliance with the License. |
||||
* You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.springframework.web.bind.annotation; |
||||
|
||||
import java.lang.annotation.Annotation; |
||||
import java.lang.annotation.Documented; |
||||
import java.lang.annotation.ElementType; |
||||
import java.lang.annotation.Retention; |
||||
import java.lang.annotation.RetentionPolicy; |
||||
import java.lang.annotation.Target; |
||||
|
||||
import org.springframework.core.annotation.AliasFor; |
||||
|
||||
/** |
||||
* A convenience annotation that is itself annotated with |
||||
* {@link ControllerAdvice @ControllerAdvice} |
||||
* and {@link ResponseBody @ResponseBody}. |
||||
* |
||||
* <p>Types that carry this annotation are treated as controller advice where |
||||
* {@link ExceptionHandler @ExceptionHandler} methods assume |
||||
* {@link ResponseBody @ResponseBody} semantics by default. |
||||
* |
||||
* @author Rossen Stoyanchev |
||||
* @since 4.3 |
||||
*/ |
||||
@Target(ElementType.TYPE) |
||||
@Retention(RetentionPolicy.RUNTIME) |
||||
@Documented |
||||
@ControllerAdvice |
||||
@ResponseBody |
||||
public @interface RestControllerAdvice { |
||||
|
||||
/** |
||||
* Alias for the {@link #basePackages} attribute. |
||||
* <p>Allows for more concise annotation declarations e.g.: |
||||
* {@code @ControllerAdvice("org.my.pkg")} is equivalent to |
||||
* {@code @ControllerAdvice(basePackages="org.my.pkg")}. |
||||
* @see #basePackages() |
||||
*/ |
||||
@AliasFor("basePackages") |
||||
String[] value() default {}; |
||||
|
||||
/** |
||||
* Array of base packages. |
||||
* <p>Controllers that belong to those base packages or sub-packages thereof |
||||
* will be included, e.g.: {@code @ControllerAdvice(basePackages="org.my.pkg")} |
||||
* or {@code @ControllerAdvice(basePackages={"org.my.pkg", "org.my.other.pkg"})}. |
||||
* <p>{@link #value} is an alias for this attribute, simply allowing for |
||||
* more concise use of the annotation. |
||||
* <p>Also consider using {@link #basePackageClasses()} as a type-safe |
||||
* alternative to String-based package names. |
||||
*/ |
||||
@AliasFor("value") |
||||
String[] basePackages() default {}; |
||||
|
||||
/** |
||||
* Type-safe alternative to {@link #value()} for specifying the packages |
||||
* to select Controllers to be assisted by the {@code @ControllerAdvice} |
||||
* annotated class. |
||||
* <p>Consider creating a special no-op marker class or interface in each package
|
||||
* that serves no purpose other than being referenced by this attribute. |
||||
*/ |
||||
Class<?>[] basePackageClasses() default {}; |
||||
|
||||
/** |
||||
* Array of classes. |
||||
* <p>Controllers that are assignable to at least one of the given types |
||||
* will be assisted by the {@code @ControllerAdvice} annotated class. |
||||
*/ |
||||
Class<?>[] assignableTypes() default {}; |
||||
|
||||
/** |
||||
* Array of annotations. |
||||
* <p>Controllers that are annotated with this/one of those annotation(s) |
||||
* will be assisted by the {@code @ControllerAdvice} annotated class. |
||||
* <p>Consider creating a special annotation or use a predefined one, |
||||
* like {@link RestController @RestController}. |
||||
*/ |
||||
Class<? extends Annotation>[] annotations() default {}; |
||||
|
||||
} |
||||
Loading…
Reference in new issue