Class WikiSession
- All Implemented Interfaces:
EventListener,Session,WikiEventListener
Default implementation for Session.
In addition to methods for examining individual WikiSession objects, this class also contains a number of static
methods for managing WikiSessions for an entire wiki. These methods allow callers to find, query and remove WikiSession objects, and
to obtain a list of the current wiki session users.
-
Field Summary
Fields inherited from interface org.apache.wiki.api.core.Session
ANONYMOUS, ASSERTED, AUTHENTICATED -
Method Summary
Modifier and TypeMethodDescriptionvoidactionPerformed(WikiEvent event) Listens for WikiEvents generated by source objects such as the GroupManager, UserManager or AuthenticationManager.voidaddMessage(String message) voidaddMessage(String topic, String message) voidvoidclearMessages(String topic) String[]String[]getMessages(String topic) getRoles()static SessiongetWikiSession(Engine engine, javax.servlet.http.HttpServletRequest request) Static factory method that returns the Session object associated with the current HTTP request.static SessionguestSession(Engine engine) Static factory method that creates a new "guest" session containing a single user PrincipalWikiPrincipal.GUEST, plus the role principalsRole.ALLandRole.ANONYMOUS.booleanhasPrincipal(Principal principal) protected voidInjects GroupPrincipal objects into the user's Principal set based on the groups the user belongs to.protected voidAdds Principal objects to the Subject that correspond to the logged-in user's profile attributes for the wiki name, full name and login name.voidbooleanbooleanbooleanprotected booleanReturnstrueif one of this WikiSession's user Principals can be shown to belong to a particular wiki group.static voidremoveWikiSession(Engine engine, javax.servlet.http.HttpServletRequest request) Removes the wiki session associated with the user's HTTP request from the cache of wiki sessions, typically as part of a logout process.static intDeprecated.static Principal[]userPrincipals(Engine engine) Deprecated.useSessionMonitor.userPrincipals()instead
-
Method Details
-
isInGroup
Returnstrueif one of this WikiSession's user Principals can be shown to belong to a particular wiki group. If the user is not authenticated, this method will always returnfalse.- Parameters:
group- the group to test- Returns:
- the result
-
isAsserted
- Specified by:
isAssertedin interfaceSession
-
isAuthenticated
- Specified by:
isAuthenticatedin interfaceSession
-
isAnonymous
- Specified by:
isAnonymousin interfaceSession
-
getLoginPrincipal
- Specified by:
getLoginPrincipalin interfaceSession
-
getUserPrincipal
- Specified by:
getUserPrincipalin interfaceSession
-
antiCsrfToken
- Specified by:
antiCsrfTokenin interfaceSession
-
getLocale
-
addMessage
- Specified by:
addMessagein interfaceSession
-
addMessage
- Specified by:
addMessagein interfaceSession
-
clearMessages
- Specified by:
clearMessagesin interfaceSession
-
clearMessages
- Specified by:
clearMessagesin interfaceSession
-
getMessages
- Specified by:
getMessagesin interfaceSession
-
getMessages
- Specified by:
getMessagesin interfaceSession
-
getPrincipals
- Specified by:
getPrincipalsin interfaceSession
-
getRoles
-
hasPrincipal
- Specified by:
hasPrincipalin interfaceSession
-
actionPerformed
Listens for WikiEvents generated by source objects such as the GroupManager, UserManager or AuthenticationManager. This method adds Principals to the private Subject managed by the WikiSession.- Specified by:
actionPerformedin interfaceWikiEventListener- See Also:
-
invalidate
- Specified by:
invalidatein interfaceSession
-
injectGroupPrincipals
Injects GroupPrincipal objects into the user's Principal set based on the groups the user belongs to. For Groups, the algorithm first calls theAuthorizer.getRoles()to obtain the array of GroupPrincipals the authorizer knows about. Then, the methodAuthorizer.isUserInRole(Session, Principal)is called for each Principal. If the user is a member of the group, an equivalent GroupPrincipal is injected into the user's principal set. Existing GroupPrincipals are flushed and replaced. This method should generally be called after a user'sUserProfileis saved. If the wiki session is null, or there is no matching user profile, the method returns silently. -
injectUserProfilePrincipals
Adds Principal objects to the Subject that correspond to the logged-in user's profile attributes for the wiki name, full name and login name. These Principals will be WikiPrincipals, and they will replace all other WikiPrincipals in the Subject. Note: this method is never called during anonymous or asserted sessions. -
getStatus
-
getSubject
- Specified by:
getSubjectin interfaceSession
-
removeWikiSession
Removes the wiki session associated with the user's HTTP request from the cache of wiki sessions, typically as part of a logout process.- Parameters:
engine- the wiki enginerequest- the user's HTTP request
-
getWikiSession
Static factory method that returns the Session object associated with the current HTTP request. This method looks up the associated HttpSession in an internal WeakHashMap and attempts to retrieve the WikiSession. If not found, one is created. This method is guaranteed to always return a Session, although the authentication status is unpredictable until the user attempts to log in. If the servlet request parameter is
null, a syntheticguestSession(Engine)is returned.When a session is created, this method attaches a WikiEventListener to the GroupManager, UserManager and AuthenticationManager, so that changes to users, groups, logins, etc. are detected automatically.
- Parameters:
engine- the enginerequest- the servlet request object- Returns:
- the existing (or newly created) session
-
guestSession
Static factory method that creates a new "guest" session containing a single user PrincipalWikiPrincipal.GUEST, plus the role principalsRole.ALLandRole.ANONYMOUS. This method also adds the session as a listener for GroupManager, AuthenticationManager and UserManager events.- Parameters:
engine- the wiki engine- Returns:
- the guest wiki session
-
sessions
Deprecated.useSessionMonitor.sessions()insteadReturns the total number of active wiki sessions for a particular wiki. This method delegates to the wiki'sSessionMonitor.sessions()method.- Parameters:
engine- the wiki session- Returns:
- the number of sessions
- See Also:
-
userPrincipals
Deprecated.useSessionMonitor.userPrincipals()insteadReturns Principals representing the current users known to a particular wiki. Each Principal will correspond to the value returned by each WikiSession'sgetUserPrincipal()method. This method delegates toSessionMonitor.userPrincipals().- Parameters:
engine- the wiki engine- Returns:
- an array of Principal objects, sorted by name
- See Also:
-
SessionMonitor.sessions()instead