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

org.apache.catalina.TomcatPrincipal Maven / Gradle / Ivy

There is a newer version: 11.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 org.apache.catalina;

import java.security.Principal;
import java.util.Collections;
import java.util.Enumeration;

import org.ietf.jgss.GSSCredential;

/**
 * Defines additional methods implemented by {@link Principal}s created by
 * Tomcat's standard {@link Realm} implementations.
 */
public interface TomcatPrincipal extends Principal {

    /**
     * @return The authenticated Principal to be exposed to applications.
     */
    Principal getUserPrincipal();

    /**
     * @return The user's delegated credentials.
     */
    GSSCredential getGssCredential();

    /**
     * Calls logout, if necessary, on any associated JAASLoginContext and/or
     * GSSContext. May in the future be extended to cover other logout
     * requirements.
     *
     * @throws Exception If something goes wrong with the logout. Uses Exception
     *                   to allow for future expansion of this method to cover
     *                   other logout mechanisms that might throw a different
     *                   exception to LoginContext
     */
    void logout() throws Exception;

    /**
     * Returns the value of the named attribute as an Object, or
     * null if no attribute of the given name exists, or if
     * null has been specified as the attribute's name.
     * 

* Only the servlet container may set attributes to make available custom * information about a Principal or the user it represents. *

* The purpose of the method is to implement read only access to attributes * which may be stored in the Realm implementation's backend * due to its inherent design. *

* As using this method from application code will make it non portable to * other EE compliant containers, it is advised this should never be used * as an object storage facility tied to the Principal, but * rather as simple extra additional metadata. It is recommended that a * container level object is used to further process the attributes that * may be associated with the Principal. *

* Realm implementations that are provided by Tomcat will * not provide complex type mapping, but will in most cases always * return a result as a String object which may need custom * decoding. *

* Realm implementations that are provided by Tomcat will * not provide an implementation for this facility unless it is inherent * to the storage backend of the Realm itself and metadata * is available without additional user intervention or configuration. * * @param name a String specifying the name of the attribute * @return an Object containing the value of the attribute, or * null if the attribute does not exist, or if * null has been specified as the attribute's name */ default Object getAttribute(String name) { return null; } /** * Returns an Enumeration containing the names of the * attributes available to this Principal. This method returns an empty * Enumeration if the Principal has no attributes available to * it. * * @return an Enumeration of strings containing the names of * the Principal's attributes */ default Enumeration getAttributeNames() { return Collections.emptyEnumeration(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy