/***
* Copyright (c) 2009 Caelum - www.caelum.com.br/opensource All rights reserved.
*
* 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 br.com.caelum.vraptor.interceptor;
import java.lang.reflect.Method;
import javax.enterprise.context.ApplicationScoped;
import javax.enterprise.inject.Instance;
import javax.inject.Inject;
import br.com.caelum.vraptor.AfterCall;
import br.com.caelum.vraptor.AroundCall;
import br.com.caelum.vraptor.BeforeCall;
/**
* Simple executor for interceptor methods containing annotations:
* {@link BeforeCall}, {@link AroundCall} or {@link AfterCall}
*
* @author Rodrigo Turini
* @since 4.0
*/
@ApplicationScoped
public class InterceptorExecutor {
private final StepInvoker stepInvoker;
private final InterceptorMethodParametersResolver parametersResolver;
private final Instance<SimpleInterceptorStack> simpleInterceptorStack;
/**
* @deprecated CDI eyes only
*/
protected InterceptorExecutor() {
this(null, null, null);
}
@Inject
public InterceptorExecutor(StepInvoker stepInvoker, InterceptorMethodParametersResolver parametersResolver,
Instance<SimpleInterceptorStack> simpleInterceptorStack) {
this.stepInvoker = stepInvoker;
this.parametersResolver = parametersResolver;
this.simpleInterceptorStack = simpleInterceptorStack;
}
/**
* @param interceptor to be executed
* @param method that should be annotated with {@link BeforeCall} or {@link AfterCall}
*/
public void execute(Object interceptor, Method method) {
if (method != null) {
stepInvoker.tryToInvoke(interceptor, method);
}
}
/**
* <strong>note</strong>: Just for this case, method can receive DI.
* @param interceptor to be executed
* @param method that should be annotated with {@link AroundCall}.
*/
public void executeAround(Object interceptor, Method method) {
if (method != null) {
Object[] params = parametersResolver.parametersFor(method);
stepInvoker.tryToInvoke(interceptor, method, params);
} else {
simpleInterceptorStack.get().next();
}
}
}