2 * This document is a part of the source code and related artifacts
3 * for CollectionSpace, an open source collections management system
4 * for museums and related institutions:
6 * http://www.collectionspace.org
7 * http://wiki.collectionspace.org
9 * Copyright 2009 University of California at Berkeley
11 * Licensed under the Educational Community License (ECL), Version 2.0.
12 * You may not use this file except in compliance with this License.
14 * You may obtain a copy of the ECL 2.0 License at
16 * https://source.collectionspace.org/collection-space/LICENSE.txt
18 * Unless required by applicable law or agreed to in writing, software
19 * distributed under the License is distributed on an "AS IS" BASIS,
20 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21 * See the License for the specific language governing permissions and
22 * limitations under the License.
25 package org.collectionspace.authentication.spi;
27 import javax.security.auth.Subject;
28 import org.collectionspace.authentication.CSpaceTenant;
31 * Utilities to be used by Services runtime to interface with authentication service
34 public abstract class AuthNContext {
37 * getUserId returns authenticated user id
40 public abstract String getUserId();
43 * getTenantIds get tenant ids from the tenant context associated with the
47 public abstract String[] getTenantIds();
50 * getCurrentTenantId get id of the tenant associated with the authenticated user
53 public abstract String getCurrentTenantId();
56 * getCurrentTenantName get name of the tenant associated with the authenticated user
59 public abstract String getCurrentTenantName();
62 * getTenants get tenant context associated with the security context
66 public abstract CSpaceTenant[] getTenants();
69 * getSubject retrieves security context as Subject
70 * @see javax.security.auth.Subject
72 public abstract Subject getSubject();