br.com.caelum.vraptor.interceptor.NoStackParamValidationRule Maven / Gradle / Ivy
/***
* 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 static com.google.common.base.Preconditions.checkState;
import static java.util.Arrays.asList;
import java.lang.reflect.Method;
import java.util.List;
import javax.enterprise.context.Dependent;
import javax.inject.Inject;
import br.com.caelum.vraptor.Accepts;
import br.com.caelum.vraptor.AfterCall;
import br.com.caelum.vraptor.AroundCall;
import br.com.caelum.vraptor.BeforeCall;
import br.com.caelum.vraptor.core.InterceptorStack;
import com.google.common.base.Predicate;
import com.google.common.collect.FluentIterable;
@Dependent
public class NoStackParamValidationRule implements ValidationRule {
private final StepInvoker invoker;
/**
* @deprecated CDI eyes only
*/
protected NoStackParamValidationRule() {
this(null);
}
@Inject
public NoStackParamValidationRule(StepInvoker invoker) {
this.invoker = invoker;
}
@Override
public void validate(Class> originalType, List methods) {
Method aroundCall = invoker.findMethod(methods, AroundCall.class, originalType);
Method afterCall = invoker.findMethod(methods, AfterCall.class, originalType);
Method beforeCall = invoker.findMethod(methods, BeforeCall.class, originalType);
Method accepts = invoker.findMethod(methods, Accepts.class, originalType);
String interceptorStack = InterceptorStack.class.getName();
String simpleInterceptorStack = SimpleInterceptorStack.class.getName();
checkState(aroundCall == null || containsStack(aroundCall), "@AroundCall method must receive %s or %s",
interceptorStack, simpleInterceptorStack);
checkState(!containsStack(beforeCall) && !containsStack(afterCall) && !containsStack(accepts),
"Non @AroundCall method must not receive %s or %s", interceptorStack, simpleInterceptorStack);
}
private boolean containsStack(Method method) {
if (method == null) {
return false;
}
List> parameterTypes = asList(method.getParameterTypes());
return FluentIterable.from(parameterTypes).anyMatch(hasStack());
}
private Predicate> hasStack() {
return new Predicate>() {
@Override
public boolean apply(Class> input) {
return SimpleInterceptorStack.class.isAssignableFrom(input)
|| InterceptorStack.class.isAssignableFrom(input);
}
};
}
}