Package io.micronaut.aop.chain
Class ConstructorInterceptorChain<T>
java.lang.Object
io.micronaut.aop.chain.ConstructorInterceptorChain<T>
- Type Parameters:
T
- The bean type
- All Implemented Interfaces:
ConstructorInvocationContext<T>
,InvocationContext<T,
,T> AnnotationMetadata
,AnnotationMetadataDelegate
,AnnotationMetadataProvider
,AnnotationSource
,AttributeHolder
,MutableAttributeHolder
,Executable<T,
T>
@Internal
public final class ConstructorInterceptorChain<T>
extends Object
implements ConstructorInvocationContext<T>
Implementation of
InvocationContext
for constructor interception.- Since:
- 3.0.0
- Author:
- graemerocher
-
Field Summary
Modifier and TypeFieldDescriptionprotected MutableConvertibleValues<Object>
protected int
protected final int
protected final Interceptor<T,
T>[] protected static final org.slf4j.Logger
Used by subclasses!protected final Object[]
protected Map<String,
MutableArgumentValue<?>> Fields inherited from interface io.micronaut.core.annotation.AnnotationMetadata
CLASS_NAME_SUFFIX, EMPTY_METADATA, VALUE_MEMBER
Fields inherited from interface io.micronaut.core.annotation.AnnotationSource
EMPTY
-
Method Summary
Modifier and TypeMethodDescriptionThe required argument types.Overrides the defaultAttributeHolder.getAttributes()
method to return a mutable object.getKind()
Returns the current parameters as a map of mutable argument values.Returns the current state of the parameters as an array by parameter index.static <T1> T1
instantiate
(@NonNull BeanResolutionContext resolutionContext, @NonNull BeanContext beanContext, @Nullable List<BeanRegistration<Interceptor<T1, T1>>> interceptors, @NonNull BeanDefinition<T1> definition, @NonNull BeanConstructor<T1> constructor, int additionalProxyConstructorParametersCount, @NonNull Object... parameters) Internal methods that handles the logic of instantiating a bean that has constructor interception applied.static <T1> T1
instantiate
(@NonNull BeanResolutionContext resolutionContext, @NonNull BeanContext beanContext, @Nullable List<BeanRegistration<Interceptor<T1, T1>>> interceptors, @NonNull BeanDefinition<T1> definition, @NonNull BeanConstructor<T1> constructor, @NonNull Object... parameters) Deprecated.Invokes the method.proceed()
Proceeds with the invocation.proceed
(@NonNull Interceptor from) Proceeds with the invocation using the given interceptor as a position to start from.protected static @NonNull Collection<AnnotationValue<?>>
resolveInterceptorValues
(@NonNull AnnotationMetadata annotationMetadata, @NonNull InterceptorKind kind) Resolve interceptor binding for the given annotation metadata and kind.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface io.micronaut.core.annotation.AnnotationMetadata
enumValuesSet, enumValuesSet, getValues, hasDeclaredStereotype, hasEvaluatedExpressions, hasStereotypeNonRepeating, isAnnotationPresent, isDeclaredAnnotationPresent
Methods inherited from interface io.micronaut.core.annotation.AnnotationMetadataDelegate
booleanValue, booleanValue, booleanValue, booleanValue, classValue, classValue, classValue, classValue, classValues, classValues, classValues, classValues, copyAnnotationMetadata, doubleValue, doubleValue, doubleValue, enumValue, enumValue, enumValue, enumValue, enumValues, enumValues, enumValues, enumValues, findAnnotation, findAnnotation, findDeclaredAnnotation, findDeclaredAnnotation, findRepeatableAnnotation, findRepeatableAnnotation, getAnnotation, getAnnotation, getAnnotationNameByStereotype, getAnnotationNameByStereotype, getAnnotationNames, getAnnotationNamesByStereotype, getAnnotationNamesByStereotype, getAnnotationType, getAnnotationType, getAnnotationTypeByStereotype, getAnnotationTypeByStereotype, getAnnotationTypesByStereotype, getAnnotationTypesByStereotype, getAnnotationTypesByStereotype, getAnnotationValuesByName, getAnnotationValuesByStereotype, getAnnotationValuesByType, getDeclaredAnnotation, getDeclaredAnnotation, getDeclaredAnnotationNameByStereotype, getDeclaredAnnotationNames, getDeclaredAnnotationNamesByStereotype, getDeclaredAnnotationTypeByStereotype, getDeclaredAnnotationTypeByStereotype, getDeclaredAnnotationValuesByName, getDeclaredAnnotationValuesByType, getDeclaredMetadata, getDeclaredStereotypeAnnotationNames, getDefaultValue, getDefaultValue, getDefaultValue, getDefaultValue, getDefaultValues, getStereotypeAnnotationNames, getTargetAnnotationMetadata, getValue, getValue, getValue, getValue, getValue, getValue, getValue, getValue, getValue, getValue, getValue, getValue, getValues, getValues, hasAnnotation, hasAnnotation, hasDeclaredAnnotation, hasDeclaredAnnotation, hasDeclaredStereotype, hasDeclaredStereotype, hasDeclaredStereotype, hasPropertyExpressions, hasSimpleAnnotation, hasSimpleDeclaredAnnotation, hasStereotype, hasStereotype, hasStereotype, hasStereotype, intValue, intValue, intValue, isAnnotationPresent, isDeclaredAnnotationPresent, isEmpty, isFalse, isFalse, isPresent, isPresent, isRepeatableAnnotation, isRepeatableAnnotation, isTrue, isTrue, longValue, longValue, stringValue, stringValue, stringValue, stringValue, stringValues, stringValues, stringValues, stringValues, synthesize, synthesize, synthesizeAll, synthesizeAnnotationsByType, synthesizeDeclared, synthesizeDeclared, synthesizeDeclared, synthesizeDeclaredAnnotationsByType
Methods inherited from interface io.micronaut.core.annotation.AnnotationMetadataProvider
getAnnotationMetadata
Methods inherited from interface io.micronaut.core.attr.AttributeHolder
getAttribute, getAttribute
Methods inherited from interface io.micronaut.aop.ConstructorInvocationContext
getDeclaringType, proceed
Methods inherited from interface io.micronaut.aop.InvocationContext
getParameters, getParameterValueMap, getParameterValues, setAttribute
Methods inherited from interface io.micronaut.core.attr.MutableAttributeHolder
getAttributes, removeAttribute
-
Field Details
-
LOG
protected static final org.slf4j.Logger LOGUsed by subclasses! -
interceptors
-
originalParameters
-
interceptorCount
protected final int interceptorCount -
attributes
-
index
protected int index -
parameters
-
-
Method Details
-
getKind
- Specified by:
getKind
in interfaceInvocationContext<T,
T> - Returns:
- An enum representing the kind of interception that is occurring.
-
getTarget
- Specified by:
getTarget
in interfaceInvocationContext<T,
T> - Returns:
- The target object
-
proceed
Description copied from interface:InvocationContext
Proceeds with the invocation. If this is the last interceptor in the chain then the final implementation method is invoked- Specified by:
proceed
in interfaceConstructorInvocationContext<T>
- Specified by:
proceed
in interfaceInvocationContext<T,
T> - Returns:
- The return value of the method
- Throws:
RuntimeException
- chain may throw RTE
-
getArguments
Description copied from interface:Executable
The required argument types.- Specified by:
getArguments
in interfaceExecutable<T,
T> - Returns:
- The arguments
-
invoke
Description copied from interface:Executable
Invokes the method.- Specified by:
invoke
in interfaceExecutable<T,
T> - Parameters:
instance
- The instance. Nullable only if it's a static method call.arguments
- The arguments- Returns:
- The result
-
getConstructor
- Specified by:
getConstructor
in interfaceConstructorInvocationContext<T>
- Returns:
- The bean type.
-
instantiate
@Internal @NonNull @Deprecated public static <T1> T1 instantiate(@NonNull @NonNull BeanResolutionContext resolutionContext, @NonNull @NonNull BeanContext beanContext, @Nullable @Nullable List<BeanRegistration<Interceptor<T1, T1>>> interceptors, @NonNull @NonNull BeanDefinition<T1> definition, @NonNull @NonNull BeanConstructor<T1> constructor, @NonNull @NonNull Object... parameters) Deprecated.Internal methods that handles the logic of instantiating a bean that has constructor interception applied.- Type Parameters:
T1
- The bean type- Parameters:
resolutionContext
- The resolution contextbeanContext
- The bean contextinterceptors
- The interceptors. Can be null and if so should be resolved from the context.definition
- The definitionconstructor
- The bean constructorparameters
- Th resolved parameters- Returns:
- The instantiated bean
- Since:
- 3.0.0
-
instantiate
@Internal @NonNull public static <T1> T1 instantiate(@NonNull @NonNull BeanResolutionContext resolutionContext, @NonNull @NonNull BeanContext beanContext, @Nullable @Nullable List<BeanRegistration<Interceptor<T1, T1>>> interceptors, @NonNull @NonNull BeanDefinition<T1> definition, @NonNull @NonNull BeanConstructor<T1> constructor, int additionalProxyConstructorParametersCount, @NonNull @NonNull Object... parameters) Internal methods that handles the logic of instantiating a bean that has constructor interception applied.- Type Parameters:
T1
- The bean type- Parameters:
resolutionContext
- The resolution contextbeanContext
- The bean contextinterceptors
- The interceptors. Can be null and if so should be resolved from the context.definition
- The definitionconstructor
- The bean constructoradditionalProxyConstructorParametersCount
- The additional proxy constructor parameters countparameters
- The resolved parameters- Returns:
- The instantiated bean
- Since:
- 3.0.0
-
getParameterValues
Description copied from interface:InvocationContext
Returns the current state of the parameters as an array by parameter index. Note that mutations to the array have no effect. If you wish to mutate the parameters useInvocationContext.getParameters()
and theMutableArgumentValue
interface instead- Specified by:
getParameterValues
in interfaceInvocationContext<B,
R> - Returns:
- The bound
ArgumentValue
instances
-
getAttributes
Description copied from interface:MutableAttributeHolder
Overrides the defaultAttributeHolder.getAttributes()
method to return a mutable object.- Specified by:
getAttributes
in interfaceAttributeHolder
- Specified by:
getAttributes
in interfaceMutableAttributeHolder
- Returns:
- The mutable attributes
-
getParameters
Description copied from interface:InvocationContext
Returns the current parameters as a map of mutable argument values. This method allows mutation of the argument values and is generally more expensive than usingInvocationContext.getParameterValues()
andExecutable.getArguments()
directly, hence should be used with care.- Specified by:
getParameters
in interfaceInvocationContext<B,
R> - Returns:
- The bound
ArgumentValue
instances
-
proceed
Description copied from interface:InvocationContext
Proceeds with the invocation using the given interceptor as a position to start from. Mainly useful forIntroduction
advise where you want to invoke the target multiple times or where you want to repeat the entire chain.- Specified by:
proceed
in interfaceInvocationContext<B,
R> - Parameters:
from
- The interceptor to start from (note: will not be included in the execution)- Returns:
- The return value of the method
- Throws:
RuntimeException
- chain may throw RTE
-
resolveInterceptorValues
@NonNull protected static @NonNull Collection<AnnotationValue<?>> resolveInterceptorValues(@NonNull @NonNull AnnotationMetadata annotationMetadata, @NonNull @NonNull InterceptorKind kind) Resolve interceptor binding for the given annotation metadata and kind.- Parameters:
annotationMetadata
- The annotation metadatakind
- The kind- Returns:
- The binding
- Since:
- 3.3.0
-