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

org.directwebremoting.spring.CreatorConfig Maven / Gradle / Ivy

/*
 * Copyright 2005 Joe Walker
 *
 * 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 org.directwebremoting.spring;

import java.util.List;
import java.util.Properties;
import java.util.ArrayList;

import org.directwebremoting.AjaxFilter;
import org.directwebremoting.extend.Creator;

/**
 * The configuration for a creator. 
* You can either specify the creator directly or specify one of the build in creator types, * for instance "new". * * It allows the specification of the following optional configuration parameters: *
    *
  • includes - the list of method names to include
  • *
  • excludes - the list of method names to exclude
  • *
  • auth - the Properties object containing method names and corresponding * required role
  • *
  • filters - the list of filter objects
  • *
* * @see org.directwebremoting.extend.AccessControl#addIncludeRule(String, String) * @see org.directwebremoting.extend.AccessControl#addExcludeRule(String, String) * @see org.directwebremoting.extend.AccessControl#addRoleRestriction(String, String, String) * @see org.directwebremoting.AjaxFilter * @see org.directwebremoting.extend.AjaxFilterManager#addAjaxFilter(org.directwebremoting.AjaxFilter, String) * * @author Bram Smeets * @author Joe Walker [joe at getahead dot ltd dot uk] */ public class CreatorConfig extends AbstractConfig { /** * The creator type that will be used to create new objects for remoting * @return Returns the creator type. */ public String getCreatorType() { return creatorType; } /** * The creator that will be used to create new objects for remoting * @param creatorType The creator type to set. */ public void setCreatorType(String creatorType) { this.creatorType = creatorType; } /** * The creator that will be used to create new objects for remoting * @return Returns the creator. */ public Creator getCreator() { return creator; } /** * The creator type that will be used to create new objects for remoting * @param creator The creator to set. */ public void setCreator(Creator creator) { this.creator = creator; } /** * Sets the authentication parameters for this creator. * @return the map containing the method name and the corrosponding required role * @see org.directwebremoting.extend.AccessControl#addRoleRestriction(String, String, String) */ public Properties getAuth() { return auth; } /** * Sets the authentication parameters for this creator. * @param auth the map containing the method name and the corrosponding required role * @see org.directwebremoting.extend.AccessControl#addRoleRestriction(String, String, String) */ public void setAuth(Properties auth) { this.auth = auth; } /** * Gets the list of all filters for this creator. * @return the list containing all filters * @see org.directwebremoting.AjaxFilter * @see org.directwebremoting.extend.AjaxFilterManager#addAjaxFilter(org.directwebremoting.AjaxFilter, String) */ public List getFilters() { return filters; } /** * Sets the list of all filters for this creator. * @param filters the list containing all filters * @see org.directwebremoting.AjaxFilter * @see org.directwebremoting.extend.AjaxFilterManager#addAjaxFilter(org.directwebremoting.AjaxFilter, String) */ public void setFilters(List filters) { this.filters = filters; } /** * Convenience method for adding an authentication rule. * @param method the method to add the authentication rule * @param role the role to add the authentication constraint for * @throws IllegalArgumentException in case the specified argument is null */ public void addAuth(String method, String role) { auth.setProperty(method, role); } /** * Convenience method for adding a filter. * @param filter the filter to add for this creator * @throws IllegalArgumentException in case the specified argument is null */ public void addFilter(AjaxFilter filter) { filters.add(filter); } /** * The creator type to use */ private String creatorType; /** * The creator to use */ private Creator creator; /** * The properties containing the method name and the corrosponding required role. */ private Properties auth = new Properties(); /** * The list of filter objects for this creator. */ private List filters = new ArrayList(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy