File: TomcatPrincipal.java

package info (click to toggle)
tomcat10 10.1.40-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 46,748 kB
  • sloc: java: 371,059; xml: 57,665; jsp: 4,654; sh: 1,381; perl: 314; makefile: 25; ansic: 15
file content (86 lines) | stat: -rw-r--r-- 4,157 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/*
 * 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.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 <code>Object</code>, or <code>null</code> if no attribute of the
     * given name exists, or if <code>null</code> has been specified as the attribute's name.
     * <p>
     * Only the servlet container may set attributes to make available custom information about a Principal or the user
     * it represents.
     * <p>
     * The purpose of the method is to implement read only access to attributes which may be stored in the
     * <code>Realm</code> implementation's backend due to its inherent design.
     * <p>
     * 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 <code>Principal</code>, 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 <code>Principal</code>.
     * <p>
     * <code>Realm</code> implementations that are provided by Tomcat will not provide complex type mapping, but will in
     * most cases always return a result as a <code>String</code> object which may need custom decoding.
     * <p>
     * <code>Realm</code> implementations that are provided by Tomcat will not provide an implementation for this
     * facility unless it is inherent to the storage backend of the <code>Realm</code> itself and metadata is available
     * without additional user intervention or configuration.
     *
     * @param name a <code>String</code> specifying the name of the attribute
     *
     * @return an <code>Object</code> containing the value of the attribute, or <code>null</code> if the attribute does
     *             not exist, or if <code>null</code> has been specified as the attribute's name
     */
    Object getAttribute(String name);

    /**
     * Returns an <code>Enumeration</code> containing the names of the attributes available to this Principal. This
     * method returns an empty <code>Enumeration</code> if the Principal has no attributes available to it.
     *
     * @return an <code>Enumeration</code> of strings containing the names of the Principal's attributes
     */
    Enumeration<String> getAttributeNames();
}