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

javax.security.auth.message.config.ServerAuthConfig Maven / Gradle / Ivy

There is a newer version: 1.0.13
Show newest version
/**
 * EasyBeans
 * Copyright (C) 2010 Bull S.A.S.
 * Contact: [email protected]
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
 * USA
 *
 * --------------------------------------------------------------------------
 * $Id: ServerAuthConfig.java 6201 2012-03-21 10:28:10Z benoitf $
 * --------------------------------------------------------------------------
 */
package javax.security.auth.message.config;

import java.util.Map;
import javax.security.auth.Subject;
import javax.security.auth.message.AuthException;

/**
 * This interface describes a configuration of ServerAuthConfiguration objects
 * for a message layer and application context (for example, the messaging context of
 * a specific application, or set of applications).
 *
 * 

* * Implementations of this interface are returned by an AnthConfigProvider. * *

* * Callers interact with a ServerAuthConfig to obtain ServerAuthContext * objects suitable for processing a given message exchange at the layer and * within the application context of the ServerAuthConfig. * * Each ServerAuthContext object is responsible for instantiating, * initializing, and invoking the one or more ServerAuthModules * encapsulated in the ServerAuthContext. * *

* * After having acquired a ServerAuthContext, a caller operates on the * context to cause it to invoke the encapsulated ServerAuthModules to * validate service requests and to secure service responses. * * @version 1.0 * @see AuthConfigProvider */ public interface ServerAuthConfig extends AuthConfig { /** * Get a ServerAuthContext instance from this ServerAuthConfig. * *

* * The implementation of this method returns a ServerAuthContext * instance that encapsulates the ServerAuthModules used to * validate requests and secure responses associated * with the given authContextID. * *

* * Specifically, this method accesses this ServerAuthConfig * object with the argument authContextID to determine the * ServerAuthModules that are to be encapsulated in the returned * ServerAuthContext instance. * *

* * The ServerAuthConfig object establishes the request * and response MessagePolicy objects that are passed to the encapsulated * modules when they are initialized by the returned ServerAuthContext * instance. It is the modules' responsibility to enforce these policies * when invoked. * * @param authContextID An identifier used to index * the provided config, or null. * This value must be identical to the value returned by * the getAuthContextID method for all * MessageInfo objects passed to the * validateRequest * method of the returned ServerAuthContext. * * @param serviceSubject A Subject that represents the source of the * service response to be secured by the acquired authentication * context. The principal and credentials of * the Subject may be used to select or acquire the * authentication context. If the Subject is not null, * additional Principals or credentials (pertaining to the source * of the response) may be added to the Subject. A null value may * be passed for this parameter. * * @param properties A Map object that may be used by * the caller to augment the properties that will be passed * to the encapsulated modules at module initialization. * The null value may be passed for this parameter. * * @return A ServerAuthContext instance that encapsulates the * ServerAuthModules used to secure and validate * requests/responses associated with the given * authContextID, * or null (indicating that no modules are configured). * * @exception AuthException If this method fails. */ public abstract ServerAuthContext getAuthContext(String authContextID, Subject serviceSubject, Map properties) throws AuthException; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy