All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.opensymphony.xwork2.interceptor.annotations.AnnotationParameterFilterInterceptor Maven / Gradle / Ivy

There is a newer version: 6.3.0.2
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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 com.opensymphony.xwork2.interceptor.annotations;

import com.opensymphony.xwork2.Action;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.opensymphony.xwork2.interceptor.Interceptor;
import com.opensymphony.xwork2.interceptor.ParameterFilterInterceptor;
import com.opensymphony.xwork2.interceptor.ParametersInterceptor;
import com.opensymphony.xwork2.util.AnnotationUtils;
import org.apache.struts2.dispatcher.HttpParameters;

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;

/**
 * Annotation based version of {@link ParameterFilterInterceptor}.
 *
 * 

* This {@link Interceptor} must be placed in the stack before the {@link ParametersInterceptor} * When a parameter matches a field that is marked {@link Blocked} then it is removed from * the parameter map. *

*

* If an {@link Action} class is marked with {@link BlockByDefault} then all parameters are * removed unless a field on the Action exists and is marked with {@link Allowed} *

* * @author martin.gilday */ public class AnnotationParameterFilterInterceptor extends AbstractInterceptor { /* (non-Javadoc) * @see com.opensymphony.xwork2.interceptor.AbstractInterceptor#intercept(com.opensymphony.xwork2.ActionInvocation) */ @Override public String intercept(ActionInvocation invocation) throws Exception { final Object action = invocation.getAction(); HttpParameters parameters = invocation.getInvocationContext().getParameters(); Object model = invocation.getStack().peek(); if (model == action) { model = null; } boolean blockByDefault = action.getClass().isAnnotationPresent(BlockByDefault.class); List annotatedFields = new ArrayList<>(); if (blockByDefault) { AnnotationUtils.addAllFields(Allowed.class, action.getClass(), annotatedFields); if (model != null) { AnnotationUtils.addAllFields(Allowed.class, model.getClass(), annotatedFields); } for (String paramName : parameters.keySet()) { boolean allowed = false; for (Field field : annotatedFields) { //TODO only matches exact field names. need to change to it matches start of ognl expression //i.e take param name up to first . (period) and match against that if (field.getName().equals(paramName)) { allowed = true; break; } } if (!allowed) { parameters = parameters.remove(paramName); } } } else { AnnotationUtils.addAllFields(Blocked.class, action.getClass(), annotatedFields); if (model != null) { AnnotationUtils.addAllFields(Blocked.class, model.getClass(), annotatedFields); } for (String paramName : parameters.keySet()) { for (Field field : annotatedFields) { //TODO only matches exact field names. need to change to it matches start of ognl expression //i.e take param name up to first . (period) and match against that if (field.getName().equals(paramName)) { parameters = parameters.remove(paramName); } } } } invocation.getInvocationContext().setParameters(parameters); return invocation.invoke(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy