Package com.iplanet.dpro.session.service
Class InternalSession
- java.lang.Object
- 
- com.iplanet.dpro.session.service.InternalSession
 
- 
- All Implemented Interfaces:
- Serializable,- AMSession,- SessionPersistenceObservable
 
 public class InternalSession extends Object implements Serializable, AMSession, SessionPersistenceObservable TheInternalSessionclass represents a Webtop internal session.A session has four states: invalid, valid, inactive, and destroyed. The initial state of a session is invalid. - See Also:
- SessionState, Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description PropertiessessionProperties
 - 
Constructor SummaryConstructors Constructor Description InternalSession()Default constructor required for deserialisation, and should not be used elsewhere.InternalSession(SessionID sid)Creates a new InternalSession with the given Session ID.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanactivate(String userDN)Changes the state of the session to ACTIVE after creation.SessionIDaddRestrictedToken(SessionID newRestrictedTokenId, TokenRestriction restriction)Add new restricted token pointing at the same session to the list.voidaddSessionEventURL(String url, SessionID sid)Adds a listener for the associated session ID.voidcacheCookieString(String cookieString)Cache the cookie string.voidclearAuthContext()Clears the authentication context from this session.AuthContextLocalgetAuthContext()Get the authentication context associated with this session.StringgetCachedCookieString()Returns the cached cookie string for this InternalSession.StringgetClientDomain()Returns the Domain of the ClientStringgetClientID()Returns Client ID, accessing this Internal Session.booleangetCookieSupport()Returns true if cookies are supported.longgetExpirationTime(TimeUnit timeUnit)Computes session object expiration time as the smallest of the remaining idle time (or purge delay if the session has already timed out) or the session lifetime limit.SessionIDgetID()Returns the SessionID of this Internal Session.longgetIdleTime()Returns the time(in seconds) for which the Internal Session has not been accessed.booleangetIsSessionUpgrade()Gets the status of theSessionif is an upgrade statelonggetMaxCachingTime()Returns the maximum caching time(in minutes) allowed for the Internal Session.longgetMaxIdleExpirationTime(TimeUnit timeUnit)Returns time at which session's idle time expires.longgetMaxIdleTime()Returns the maximum idle time(in minutes) for the Internal Session.longgetMaxSessionExpirationTime(TimeUnit timeUnit)Returns time at which session's lifetime expires.longgetMaxSessionTime()Returns maximum time allowed for the Internal Session.ObjectgetObject(String key)Returns the value of the specified key from the internal object map.StringgetProperty(String key)Returns the value of the specified key from the Internal Session property table.EnumerationgetPropertyNames()Returns the Enumeration of property names of the Internal Session property table.SessionIDgetRestrictedTokenForRestriction(TokenRestriction restriction)Returns the SessionID of the restricted token for the provided restriction for this session.Set<SessionID>getRestrictedTokens()Returns the set (possibly empty) of restricted session IDs associated with this session.TokenRestrictiongetRestrictionForToken(SessionID sid)Returns the TokenRestriction for the given SessionID.Map<String,Set<SessionID>>getSessionEventURLs()Returns the URL of the Session events and the associated master and restricted token ids.StringgetSessionHandle()Returns the session handle.SessionIDgetSessionID()Return the SessionID object which represents this InternalSession.SessionStategetState()Returns the state of the Internal SessionlonggetTimeLeft()Returns the total time left(in seconds) for the Internal Session.SessionTypegetType()Returns the type of Internal Session.StringgetUUID()Gets the User Universal IDbooleanhasAuthenticationContext()Gets whether this session has an associated authenticationContext.booleanisAppSession()Determine whether it is an application session.booleanisInvalid()static booleanisProtectedProperty(String key)Helper method to check if a property is protected or not.booleanisStored()Returns whether the InternalSession represented has been stored.booleanisTimedOut()Returns true if the session has timed out due to idle/max timeout period.booleanisUserSession()Determine whether it is a user session.voidnotifyPersistenceManager()voidputExternalProperty(SSOToken clientToken, String key, String value)Sets the key-value pair in the InternalSession property table if it is not protected.voidputProperty(String key, String value)Sets the key-value pair in the Internal Session property table.voidremoveObject(String key)Removes the mapping for this key from the internal object map if present.voidsetAuthContext(AuthContextLocal authContext)Sets the authentication context.voidsetClientDomain(String domain)Sets the Clieant's Domain.voidsetClientID(String id)Sets Client ID for this Internal Session.voidsetCookieMode(Boolean cookieMode)set the cookieMode based on whether the request has cookies or not.voidsetCreationTime()Sets the creation time of the Internal Session, as the number of seconds since midnight January 1, 1970 GMT.voidsetDebug(Debug debug)The debug instance is not restored during deserialisation.voidsetIsSessionUpgrade(boolean value)Sets the status of the isSessionUpgrade flag to which determines if theSessionis in the upgrade state or not.voidsetLatestAccessTime()Sets the last time the client sent a request associated with this session, as the number of seconds since midnight January 1, 1970 GMT.voidsetMaxCachingTime(long t)Sets the maximum caching time(in minutes) for the Internal Session.voidsetMaxIdleTime(long maxIdleTimeInMinutes)Sets the maximum idle time (in minutes) for the Internal Session.voidsetMaxSessionTime(long maxSessionTimeInMinutes)Sets the maximum time (in minutes) allowed for the Internal SessionvoidsetNonExpiring()Sets the willExpireFlag.voidsetObject(String key, Object value)Sets the key-value pair in the internal object map.voidsetPersistenceManager(SessionPersistenceManager manager)Set the manager which handles persistence of this observable.voidsetSessionHandle(String sessionHandle)Used during session deserialization.voidsetSessionServiceDependencies(SessionService service, SessionServiceConfig serviceConfig, InternalSessionEventBroker internalSessionEventBroker, SessionUtilsWrapper sessionUtilsWrapper, SessionConstraint sessionConstraint, Debug debug)The SessionService is not restored during deserialisation.voidsetState(SessionState sessionState)Sets theSessionStateof the Internal Session.voidsetTimedOutTime(long timeoutTime)Sets session timeout time (in millis).voidsetType(SessionType type)Set the type of Internal Session.SessionInfotoSessionInfo()SessionInfotoSessionInfo(boolean withIds)Transfers the info about the Internal Session to Session Info.StringtoString()booleanwillExpire()Returns the value of willExpireFlag.
 
- 
- 
- 
Field Detail- 
sessionPropertiespublic Properties sessionProperties 
 
- 
 - 
Constructor Detail- 
InternalSessionpublic InternalSession(SessionID sid) Creates a new InternalSession with the given Session ID. Note: This InternalSession will be in an invalid state.- Parameters:
- sid- SessionID Non null Session ID.
 
 - 
InternalSessionpublic InternalSession() Default constructor required for deserialisation, and should not be used elsewhere. When deserialised the code responsible for instantiating it will have no means of resolving dependencies. Instead this is deferred tosetSessionServiceDependencies(SessionService, SessionServiceConfig, InternalSessionEventBroker, SessionUtilsWrapper, SessionConstraint, Debug)
 
- 
 - 
Method Detail- 
setDebugpublic void setDebug(Debug debug) The debug instance is not restored during deserialisation.- Parameters:
- debug- Non null debug instance.
 
 - 
setSessionServiceDependenciespublic void setSessionServiceDependencies(SessionService service, SessionServiceConfig serviceConfig, InternalSessionEventBroker internalSessionEventBroker, SessionUtilsWrapper sessionUtilsWrapper, SessionConstraint sessionConstraint, Debug debug) The SessionService is not restored during deserialisation.- Parameters:
- service- Non null SessionService.
 
 - 
getIDpublic SessionID getID() Returns the SessionID of this Internal Session.
 - 
getTypepublic SessionType getType() Returns the type of Internal Session.- Returns:
- USERor- APPLICATION.
 
 - 
setTypepublic void setType(SessionType type) Set the type of Internal Session. User OR Application.- Parameters:
- type-- USERor- APPLICATION.
 
 - 
getClientIDpublic String getClientID() Returns Client ID, accessing this Internal Session.- Returns:
- Client ID.
 
 - 
setClientIDpublic void setClientID(String id) Sets Client ID for this Internal Session.- Parameters:
- id-
 
 - 
getClientDomainpublic String getClientDomain() Returns the Domain of the Client- Returns:
- Client Domain
 
 - 
setClientDomainpublic void setClientDomain(String domain) Sets the Clieant's Domain.- Parameters:
- domain- Client Domain
 
 - 
getMaxSessionTimepublic long getMaxSessionTime() Returns maximum time allowed for the Internal Session.- Returns:
- the number of maximum minutes for the session
 
 - 
setMaxSessionTimepublic void setMaxSessionTime(long maxSessionTimeInMinutes) Sets the maximum time (in minutes) allowed for the Internal Session- Parameters:
- maxSessionTimeInMinutes- Maximum Session Time
 
 - 
getMaxIdleTimepublic long getMaxIdleTime() Returns the maximum idle time(in minutes) for the Internal Session.- Returns:
- the number maximum idle minutes
 
 - 
setMaxIdleTimepublic void setMaxIdleTime(long maxIdleTimeInMinutes) Sets the maximum idle time (in minutes) for the Internal Session.- Parameters:
- maxIdleTimeInMinutes-
 
 - 
getMaxCachingTimepublic long getMaxCachingTime() Returns the maximum caching time(in minutes) allowed for the Internal Session.- Returns:
- Maximum Cache Time
 
 - 
setMaxCachingTimepublic void setMaxCachingTime(long t) Sets the maximum caching time(in minutes) for the Internal Session.- Parameters:
- t- Maximum Caching Time
 
 - 
getIdleTimepublic long getIdleTime() Returns the time(in seconds) for which the Internal Session has not been accessed.- Returns:
- session idle time
 
 - 
getTimeLeftpublic long getTimeLeft() Returns the total time left(in seconds) for the Internal Session. Returns 0 if the time left is negative.- Returns:
- Time left for the internal session to be invalid
 
 - 
isTimedOutpublic boolean isTimedOut() Returns true if the session has timed out due to idle/max timeout period.- Returns:
- trueif the Internal session has timedout ,- falseotherwise
 
 - 
cacheCookieStringpublic void cacheCookieString(String cookieString) Cache the cookie string. No guarantees are made as to its continued persistence.- Parameters:
- cookieString- The cookie string to persist.
 
 - 
getCachedCookieStringpublic String getCachedCookieString() Returns the cached cookie string for this InternalSession. May be null.- Returns:
- The cached cookie string. May be null.
 
 - 
getSessionIDpublic SessionID getSessionID() Return the SessionID object which represents this InternalSession.- Returns:
- The session ID.
 
 - 
getStatepublic SessionState getState() Returns the state of the Internal Session- Returns:
- the session state can be VALID, INVALID, INACTIVE or DESTROYED
 
 - 
getAuthContextpublic AuthContextLocal getAuthContext() Get the authentication context associated with this session.- Returns:
- the AuthContextLocal associated with this session
 
 - 
hasAuthenticationContextpublic boolean hasAuthenticationContext() Gets whether this session has an associated authenticationContext.- Returns:
- true if this session has an authentication context.
 
 - 
setAuthContextpublic void setAuthContext(AuthContextLocal authContext) Sets the authentication context.- Parameters:
- authContext- the authentication context
 
 - 
clearAuthContextpublic void clearAuthContext() Clears the authentication context from this session.
 - 
getPropertypublic String getProperty(String key) Returns the value of the specified key from the Internal Session property table.- Parameters:
- key- Property key
- Returns:
- string value for the key from Internal Session table.
 
 - 
getPropertyNamespublic Enumeration getPropertyNames() Returns the Enumeration of property names of the Internal Session property table.- Returns:
- list of properties in the Internal session table.
 
 - 
isProtectedPropertypublic static boolean isProtectedProperty(String key) Helper method to check if a property is protected or not. We introduce a mechanism to protect certain "core" or "internal" properties from updates via remote SetProperty method of the SessionService. Allowing remote self-updates to session properties leads to a security vulnerability which allows unconstrained user impersonation or privilege elevation. See bug # 4814922 for more information protectedProperties contains a set of property names which can not be remotely updated. It is initially populated using static initializer. We also implemented an extra safety mechanism intended to protect from accidental reopening of this security hole in the future if a property name changes or new property is introduced without corresponding update of the static hardcoded list of protected properties below. This mechanism automatically adds any property to protectedProperties if it is set via local invocation of putProperty. However, some properties (such as Locale and CharSet) must be settable both locally and remotely. In order to make it configurable we use a second table called remotelyUpdateableProperties. Note that protectedProperties takes precedence over remotelyUpdateableProperties: remotelyUpdateableProperties will be consulted only if a property is not on the protectedProperties list already. The following tables defines the behavior of putProperty() and putExternalProperty() depending on whether property name is present in protectedProperties or remotelyUpdateableProperty list protectedProperties remotelyUpdateableProperties putProperty() putExternalProperty() in n/a sets value logs, does nothing out in sets value sets value out out sets value and sets value adds to protectedProperty- Parameters:
- key- property name.
- Returns:
- true if property is protected else false.
 
 - 
putExternalPropertypublic void putExternalProperty(SSOToken clientToken, String key, String value) throws SessionException Sets the key-value pair in the InternalSession property table if it is not protected. If it is protected client should have permission to set it. This method is to be used in conjuction with SessionRequestHandler/SessionService invocation path If the property is protected, an attempt to remotely set a protected property is logged and the method throws an Exception. Otherwise invocation is delegated to internalPutProperty() Note that package default access is being used- Parameters:
- clientToken- Token of the client setting external property.
- key- Property key
- value- Property value for the key
- Throws:
- SessionException- is thrown if the key is protected property.
 
 - 
putPropertypublic void putProperty(String key, String value) Sets the key-value pair in the Internal Session property table. This method should only be invoked locally by code running in the same server VM. Remote invocations should use putExternalProperty(). This is a simple wrapper around internalPutProperty(), which in addition calls to registerProtectedProperty() to make sure that if a property key is not already on the list of protected properties, it will be automatically added there (unless it is also on remotelyUpdateableProperties list!)- Parameters:
- key- Property key
- value- Property value for the key
 
 - 
setIsSessionUpgradepublic void setIsSessionUpgrade(boolean value) Sets the status of the isSessionUpgrade flag to which determines if theSessionis in the upgrade state or not.- Parameters:
- value-- trueif it is an upgrade- falseotherwise
 
 - 
getIsSessionUpgradepublic boolean getIsSessionUpgrade() Gets the status of theSessionif is an upgrade state- Returns:
- trueif the session is in upgrade state- falseotherwise
 
 - 
isStoredpublic boolean isStored() Returns whether the InternalSession represented has been stored. If this is true, changes to this object will update the stored version. returntrueif the internal session is storedfalseotherwise
 - 
activatepublic boolean activate(String userDN) Changes the state of the session to ACTIVE after creation.- Parameters:
- userDN-
- Returns:
- trueif the session is successfully activated after creation ,- falseotherwise
 
 - 
getUUIDpublic String getUUID() Gets the User Universal ID- Returns:
- UUID
 
 - 
setNonExpiringpublic void setNonExpiring() Sets the willExpireFlag. This flag specify that whether the session will ever expire or not.
 - 
setTimedOutTimepublic void setTimedOutTime(long timeoutTime) Sets session timeout time (in millis).- Parameters:
- timeoutTime- The timeout time (in millis).
 
 - 
toSessionInfopublic SessionInfo toSessionInfo() 
 - 
toSessionInfopublic SessionInfo toSessionInfo(boolean withIds) Transfers the info about the Internal Session to Session Info.- Returns:
- SessionInfo
 
 - 
setLatestAccessTimepublic void setLatestAccessTime() Sets the last time the client sent a request associated with this session, as the number of seconds since midnight January 1, 1970 GMT. Once updated the Session will be persisted.
 - 
setStatepublic void setState(SessionState sessionState) Sets theSessionStateof the Internal Session.- Parameters:
- sessionState-
 
 - 
getSessionEventURLspublic Map<String,Set<SessionID>> getSessionEventURLs() Returns the URL of the Session events and the associated master and restricted token ids.- Returns:
- Map of session event URLs and their associated SessionIDs.
 
 - 
addSessionEventURLpublic void addSessionEventURL(String url, SessionID sid) Adds a listener for the associated session ID.- Parameters:
- url- The listening URL.
- sid- The associated SessionID.
 
 - 
willExpirepublic boolean willExpire() Returns the value of willExpireFlag.
 - 
isAppSessionpublic boolean isAppSession() Determine whether it is an application session.- Returns:
- trueif this is an application session,- falseotherwise.
 
 - 
isUserSessionpublic boolean isUserSession() Determine whether it is a user session.- Returns:
- trueif this is a user session,- falseotherwise.
 
 - 
setCreationTimepublic void setCreationTime() Sets the creation time of the Internal Session, as the number of seconds since midnight January 1, 1970 GMT.
 - 
addRestrictedTokenpublic SessionID addRestrictedToken(SessionID newRestrictedTokenId, TokenRestriction restriction) Add new restricted token pointing at the same session to the list.- Parameters:
- newRestrictedTokenId- The session ID.
- restriction- The token restriction.
- Returns:
- The restricted token id for this TokenRestriction.
 
 - 
getRestrictionForTokenpublic TokenRestriction getRestrictionForToken(SessionID sid) Returns the TokenRestriction for the given SessionID.- Parameters:
- sid- Possibly null SessionID.
- Returns:
- Null indicates there is no restriction on the Session.
 
 - 
getRestrictedTokenForRestrictionpublic SessionID getRestrictedTokenForRestriction(TokenRestriction restriction) Returns the SessionID of the restricted token for the provided restriction for this session.- Parameters:
- restriction- restriction used to look up restricted token.
- Returns:
- restricted token sessionID.
 
 - 
getRestrictedTokenspublic Set<SessionID> getRestrictedTokens() Returns the set (possibly empty) of restricted session IDs associated with this session. A restricted session ID can only be used when the associatedTokenRestrictionis satisfied. Typically this ties a particular user session to only be used via a particular agent or from a particular IP address.The result is a copy of the current restricted token set: modifications to it will not change the set of restricted tokens associated with the session. - Returns:
- the set of restricted tokens associated with this session. Never null but can be empty.
 
 - 
getCookieSupportpublic boolean getCookieSupport() Returns true if cookies are supported.- Returns:
- true if cookie supported;
 
 - 
setCookieModepublic void setCookieMode(Boolean cookieMode) set the cookieMode based on whether the request has cookies or not. This method is called from createSSOToken(request) method in SSOTokenManager.- Parameters:
- cookieMode- , Boolean value whether request has cookies or not.
 
 - 
setSessionHandlepublic void setSessionHandle(String sessionHandle) Used during session deserialization. This method SHALL NOT be invoked by custom code.- Parameters:
- sessionHandle- The sessionHandle to set.
 
 - 
getSessionHandlepublic String getSessionHandle() Returns the session handle.- Returns:
- The session handle.
 
 - 
getExpirationTimepublic long getExpirationTime(TimeUnit timeUnit) Computes session object expiration time as the smallest of the remaining idle time (or purge delay if the session has already timed out) or the session lifetime limit.Time value is returned in the requested unit (accurate to millisecond) and uses the same epoch as System.currentTimeMillis().- Parameters:
- timeUnit- the time unit to return the result in.
- Returns:
- the result in the given units.
 
 - 
getMaxSessionExpirationTimepublic long getMaxSessionExpirationTime(TimeUnit timeUnit) Returns time at which session's lifetime expires.Time value is returned in the requested unit (accurate to millisecond) and uses the same epoch as System.currentTimeMillis().- Parameters:
- timeUnit- the time unit to return the result in.
- Returns:
- the result in the given units.
- See Also:
- getMaxSessionTime()
 
 - 
getMaxIdleExpirationTimepublic long getMaxIdleExpirationTime(TimeUnit timeUnit) Returns time at which session's idle time expires.Time value is returned in the requested unit (accurate to millisecond) and uses the same epoch as System.currentTimeMillis().- Parameters:
- timeUnit- the time unit to return the result in.
- Returns:
- the result in the given units.
- See Also:
- getMaxIdleTime()
 
 - 
isInvalidpublic boolean isInvalid() - Returns:
- True if the Session has reached an invalid state.
 
 - 
setPersistenceManagerpublic void setPersistenceManager(SessionPersistenceManager manager) Description copied from interface:SessionPersistenceObservableSet the manager which handles persistence of this observable.- Specified by:
- setPersistenceManagerin interface- SessionPersistenceObservable
- Parameters:
- manager- The manager to add.
 
 - 
notifyPersistenceManagerpublic void notifyPersistenceManager() 
 - 
getObjectpublic Object getObject(String key) Returns the value of the specified key from the internal object map.- Parameters:
- key- the key whose associated value is to be returned
- Returns:
- internal object
 
 - 
removeObjectpublic void removeObject(String key) Removes the mapping for this key from the internal object map if present.- Parameters:
- key- key whose mapping is to be removed from the map
 
 
- 
 
-