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

org.apache.fulcrum.intake.IntakeService Maven / Gradle / Ivy

The newest version!
package org.apache.fulcrum.intake;

/*
 * 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.
 */

import java.beans.IntrospectionException;
import java.lang.reflect.Method;

import org.apache.fulcrum.intake.model.Group;

/**
 * This service provides access to input processing objects based
 * on an XML specification.
 *
 * 

Localization of Intake's error messages can be accomplished * using Turbine's LocalizationTool from a Velocity template * as follows: * * $l10n.get($intake.SomeGroup.SomeField.Message) * *

* * @author John McNally * @author Henning P. Schmiedehausen * @author Quinton McCombs * @version $Id$ */ public interface IntakeService { /** Avalon role - used to id the component within the manager */ String ROLE = IntakeService.class.getName(); /** * The configuration property specifying the location of the xml specification. */ String XML_PATHS = "xmlPaths"; /** * The default location of the xml specification. */ String XML_PATH_DEFAULT = "WEB-INF/conf/intake.xml"; /** * The configuration property specifying the location where a serialized version of the * xml specification can be written for faster restarts.. */ String SERIAL_XML = "serialDataPath"; /** * The default location where a serialized version of * the xml specification can be written for faster restarts.. */ String SERIAL_XML_DEFAULT = "WEB-INF/appData.ser"; /** * The default pool capacity. */ int DEFAULT_POOL_CAPACITY = 1024; /** * Gets an instance of a named group either from the pool * or by calling the Factory Service if the pool is empty. * * @param groupName the name of the group. * @return a Group instance. * @throws IntakeException if recycling fails. */ Group getGroup(String groupName) throws IntakeException; /** * Puts a group back to the pool. * @param instance the object instance to recycle. * * @throws IntakeException The passed group name does not exist. */ void releaseGroup(Group instance) throws IntakeException; /** * Gets the current size of the pool for a named group. * * @param groupName the name of the group. * @return the size of the group pool * @throws IntakeException The passed group name does not exist. */ int getSize(String groupName) throws IntakeException; /** * Names of all the defined groups. * * @return array of names. */ String[] getGroupNames(); /** * Gets the key (usually a short identifier) for a group. * * @param groupName the name of the group. * @return the key. */ String getGroupKey(String groupName); /** * Gets the group name given its key. * * @param groupKey the key. * @return groupName the name of the group. */ String getGroupName(String groupKey); /** * Gets the Method that can be used to set a property. * * @param className the name of the object. * @param propName the name of the property. * @return the setter. * @throws ClassNotFoundException if the class specified could not be loaded * @throws IntrospectionException if the property setter could not be called */ Method getFieldSetter(String className, String propName) throws ClassNotFoundException, IntrospectionException; /** * Gets the Method that can be used to get a property value. * * @param className the name of the object. * @param propName the name of the property. * @return the getter. * @throws ClassNotFoundException if the class specified could not be loaded * @throws IntrospectionException if the property getter could not be called */ Method getFieldGetter(String className, String propName) throws ClassNotFoundException, IntrospectionException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy