I was looking how to implement a filter in Play Framework 2 and, for the best of my knowledge, the best approach is to implement that using action composition.
That said, I started doing some testing and I was able to make that to work. The only limitation is when I have nested annotations in the same class.
My current use case
Perform domain validation when domain parameter is present in the request.
If the domain is not present in the local database, perform syntax validation only.
Otherwise, full validation is required (what is full validation is not important here).
My current code using action composition
The controller has two annotations:
- one for most of the cases where the full domain verification is required.
- another annotation specifically for addCustomer where I want to perform syntax validation only.
There are two "problems" though. I was expecting the DomainVerifierFiler action to be called only once with the augmented property (syntaxVerificationOnly). Here is what happens:
- The "filter" is being called twice for addCustomer;
- The first one to be called is the method annotation (class annotation always overrides the method);
@DomainVerificationFilter
public class CustomerController {
public Result updateCustomer(String domain) {}
public Result deleteCustomer(String domain) {}
@DomainVerificationFilter(syntaxVerificationOnly = true)
public Result addCustomer(String domain) {}
}
@With(DomainVerifierAction.class)
@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface DomainVerifierFilter {
boolean syntaxVerificationOnly() default false;
}
public class DomainVerifierAction extends Action<DomainVerifierFilter> {
@Override
public Result call(Http.Context ctx) throws Throwable {
if (configuration.syntaxVerificationOnly()) {
//sintax verification
} else {
//full verification
}
}
}
Question: Is there any fix for this? Am I doing the wrong approach here? Any suggestions?
The current workaround is that I'm checking if it is the second call to the same action. If yes, I go ahead without checking. But this is clearly not desired.
Another possibility is to add the annotation in every method. This is also not desired because I have lots of methods with the domain as the parameter. And, 99.99% I need to perform full domain verification.
Kr, Alan