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

jakarta.security.jacc.PolicyContextHandler Maven / Gradle / Ivy

/*
 * Copyright (c) 1997, 2020 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package jakarta.security.jacc;

/**
 * This interface defines the methods that must be implemented by handlers that are to be registered and activated by
 * the PolicyContext class.
 * 
 * 

* The PolicyContext class provides methods for containers to register and activate container-specific * PolicyContext handlers. Policy providers use the PolicyContext class to * activate handlers to obtain (from the container) additional policy relevant context to apply in their access * decisions. All handlers registered and activated via the PolicyContext class must implement the * PolicyContextHandler interface. * * @see PolicyContext * @see PolicyContextException * * @author Ron Monzillo * @author Gary Ellison */ public interface PolicyContextHandler { /** * This public method returns a boolean result indicating whether or not the handler supports the context object * identified by the (case-sensitive) key value. * * @param key a String value identifying a context object that could be supported by the handler. The value * of this parameter must not be null. * * @return a boolean indicating whether or not the context object corresponding to the argument key is handled by the * handler. * * @throws PolicyContextException if the implementation throws a checked exception that has not been * accounted for by the method signature. The exception thrown by the implementation class will be encapsulated (during * construction) in the thrown PolicyContextException */ boolean supports(String key) throws PolicyContextException; /** * This public method returns the keys identifying the context objects supported by the handler. The value of each key * supported by a handler must be a non-null String value. * * @return an array containing String values identifying the context objects supported by the handler. The * array must not contain duplicate key values. In the unlikely case that the Handler supports no keys, the handler must * return a zero length array. The value null must never be returned by this method. * * @throws PolicyContextException if the implementation throws a checked exception that has not been * accounted for by the method signature. The exception thrown by the implementation class will be encapsulated (during * construction) in the thrown PolicyContextException */ String[] getKeys() throws PolicyContextException; /** * This public method is used by the PolicyContext class to activate the handler and obtain from it the * context object identified by the (case-sensitive) key. In addition to the key, the handler will be activated with the * handler data value associated within the PolicyContext class with the thread on which the call to this * method is made. * *

* Note that the policy context identifier associated with a thread is available to the handler by calling * PolicyContext.getContextID(). * * @param key a String that identifies the context object to be returned by the handler. The value of this parameter must * not be null. * @param data the handler data Object associated with the thread on which the call to this method has been * made. Note that the value passed through this parameter may be null. * @return The container and handler specific Object containing the desired context. A null * value may be returned if the value of the corresponding context is null. * * @throws PolicyContextException if the implementation throws a checked exception that has not been * accounted for by the method signature. The exception thrown by the implementation class will be encapsulated (during * construction) in the thrown PolicyContextException */ Object getContext(String key, Object data) throws PolicyContextException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy