public abstract class AbstractSecurityService extends java.lang.Object implements DestroyableResource, SecurityService<java.util.UUID>, ThreadContextListener, BasicPolicyConfiguration.RoleResolver
| Modifier and Type | Class and Description | 
|---|---|
| static class  | AbstractSecurityService.Group | 
| protected static class  | AbstractSecurityService.Identity | 
| static class  | AbstractSecurityService.ProvidedSecurityContext | 
| static class  | AbstractSecurityService.SecurityContext | 
| static class  | AbstractSecurityService.User | 
| Modifier and Type | Field and Description | 
|---|---|
| protected static java.lang.ThreadLocal<AbstractSecurityService.Identity> | clientIdentity | 
| protected AbstractSecurityService.SecurityContext | defaultContext | 
| protected javax.security.auth.Subject | defaultSubject | 
| protected java.lang.String | defaultUser | 
| protected static java.lang.String | KEY_REQUEST | 
| protected static java.lang.String | KEY_SUBJECT | 
| protected static java.util.Set<java.lang.String> | KEYS | 
| Constructor and Description | 
|---|
| AbstractSecurityService() | 
| AbstractSecurityService(java.lang.String jaccProvider) | 
| Modifier and Type | Method and Description | 
|---|---|
| void | associate(java.util.UUID securityIdentity)Active | 
| protected static java.lang.String | autoJaccProvider() | 
| void | contextEntered(ThreadContext oldContext,
              ThreadContext newContext)A new context has been entered. | 
| void | contextExited(ThreadContext exitedContext,
             ThreadContext reenteredContext)A context has exited. | 
| protected javax.security.auth.Subject | createRunAsSubject(java.lang.String runAsUser,
                  java.lang.String runAsRole) | 
| protected javax.security.auth.Subject | createSubject(java.lang.String name,
             java.lang.String groupName) | 
| java.lang.Object | currentState() | 
| void | destroyResource() | 
| java.util.UUID | disassociate()Active | 
| java.security.Principal | getCallerPrincipal()Implementors are encouraged to return a java.security.Principal
 object that implements org.apache.openejb.spi.CallerPrincipal
 JAAS LoginModule implementors are encouraged to use the CallerPrincipal
 interface to denote the best fitting Principal for getCallerPrincipal. | 
| java.lang.Object | getContext(java.lang.String key,
          java.lang.Object data) | 
| protected AbstractSecurityService.SecurityContext | getDefaultSecurityContext() | 
| java.lang.String | getDefaultUser() | 
| java.lang.String[] | getKeys() | 
| java.util.Set<java.lang.String> | getLogicalRoles(java.security.Principal[] principals,
               java.util.Set<java.lang.String> logicalRoles) | 
| <P extends java.security.Principal> | getPrincipalsByType(java.lang.Class<P> pType) | 
| java.security.ProtectionDomain | getProtectionDomain() | 
| java.lang.String | getRealmName() | 
| javax.security.auth.Subject | getRunAsSubject(BeanContext callingBeanContext) | 
| protected javax.security.auth.Subject | getSubject() | 
| void | init(java.util.Properties props) | 
| protected static void | installJacc() | 
| boolean | isCallerAuthorized(java.lang.reflect.Method method,
                  InterfaceType type)Active | 
| boolean | isCallerInRole(java.lang.String role)Active | 
| java.util.UUID | login(java.lang.String username,
     java.lang.String password) | 
| void | logout(java.util.UUID securityIdentity)Active | 
| void | onLogout(HttpServletRequest request)Called when request.logout() is triggered. | 
| java.util.UUID | overrideWithRunAsContext(ThreadContext ctx,
                        BeanContext newContext,
                        BeanContext oldContext) | 
| protected java.util.UUID | registerSubject(javax.security.auth.Subject subject) | 
| void | setDefaultUser(java.lang.String defaultUser) | 
| void | setRealmName(java.lang.String realmName) | 
| void | setState(java.lang.Object o) | 
| boolean | supports(java.lang.String key) | 
| protected void | unregisterSubject(java.lang.Object securityIdentity) | 
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitloginprotected static final java.lang.String KEY_SUBJECT
protected static final java.lang.String KEY_REQUEST
protected static final java.util.Set<java.lang.String> KEYS
protected static final java.lang.ThreadLocal<AbstractSecurityService.Identity> clientIdentity
protected java.lang.String defaultUser
protected javax.security.auth.Subject defaultSubject
protected AbstractSecurityService.SecurityContext defaultContext
public AbstractSecurityService()
public AbstractSecurityService(java.lang.String jaccProvider)
public void destroyResource()
destroyResource in interface DestroyableResourcepublic void onLogout(HttpServletRequest request)
SecurityServiceonLogout in interface SecurityService<java.util.UUID>request - the http request triggering the logout.public java.lang.String getRealmName()
public void setRealmName(java.lang.String realmName)
public java.lang.String getDefaultUser()
public void setDefaultUser(java.lang.String defaultUser)
defaultUser - the defaultUser to setpublic void init(java.util.Properties props)
          throws java.lang.Exception
public java.util.UUID login(java.lang.String username,
                            java.lang.String password)
                     throws javax.security.auth.login.LoginException
login in interface SecurityService<java.util.UUID>javax.security.auth.login.LoginExceptionpublic java.util.Set<java.lang.String> getLogicalRoles(java.security.Principal[] principals,
                                                       java.util.Set<java.lang.String> logicalRoles)
getLogicalRoles in interface BasicPolicyConfiguration.RoleResolverpublic void contextEntered(ThreadContext oldContext, ThreadContext newContext)
ThreadContextListenercontextEntered in interface ThreadContextListeneroldContext - the old context that was associated with the threadnewContext - the new context that is now associated with the threadpublic java.util.UUID overrideWithRunAsContext(ThreadContext ctx, BeanContext newContext, BeanContext oldContext)
public javax.security.auth.Subject getRunAsSubject(BeanContext callingBeanContext)
protected javax.security.auth.Subject createRunAsSubject(java.lang.String runAsUser,
                                                         java.lang.String runAsRole)
public void contextExited(ThreadContext exitedContext, ThreadContext reenteredContext)
ThreadContextListenercontextExited in interface ThreadContextListenerexitedContext - the context that was exitedreenteredContext - the context that is not associated with the threadprotected java.util.UUID registerSubject(javax.security.auth.Subject subject)
public void logout(java.util.UUID securityIdentity)
            throws javax.security.auth.login.LoginException
SecurityServicelogout in interface SecurityService<java.util.UUID>javax.security.auth.login.LoginExceptionprotected void unregisterSubject(java.lang.Object securityIdentity)
public void associate(java.util.UUID securityIdentity)
               throws javax.security.auth.login.LoginException
SecurityServiceassociate in interface SecurityService<java.util.UUID>javax.security.auth.login.LoginExceptionpublic java.util.UUID disassociate()
SecurityServicedisassociate in interface SecurityService<java.util.UUID>public boolean isCallerInRole(java.lang.String role)
SecurityServiceisCallerInRole in interface SecurityService<java.util.UUID>protected javax.security.auth.Subject getSubject()
public <P extends java.security.Principal> java.util.Set<P> getPrincipalsByType(java.lang.Class<P> pType)
getPrincipalsByType in interface SecurityService<java.util.UUID>public java.security.ProtectionDomain getProtectionDomain()
getProtectionDomain in interface SecurityService<java.util.UUID>public java.security.Principal getCallerPrincipal()
SecurityServicegetCallerPrincipal in interface SecurityService<java.util.UUID>public boolean isCallerAuthorized(java.lang.reflect.Method method,
                                  InterfaceType type)
SecurityServiceisCallerAuthorized in interface SecurityService<java.util.UUID>protected static java.lang.String autoJaccProvider()
protected static void installJacc()
protected javax.security.auth.Subject createSubject(java.lang.String name,
                                                    java.lang.String groupName)
public java.lang.Object currentState()
currentState in interface SecurityService<java.util.UUID>public void setState(java.lang.Object o)
setState in interface SecurityService<java.util.UUID>protected AbstractSecurityService.SecurityContext getDefaultSecurityContext()
public boolean supports(java.lang.String key)
                 throws PolicyContextException
PolicyContextExceptionpublic java.lang.String[] getKeys()
                           throws PolicyContextException
PolicyContextExceptionpublic java.lang.Object getContext(java.lang.String key,
                                   java.lang.Object data)
                            throws PolicyContextException
PolicyContextException