Package org.apache.wiki.auth.user
Interface UserProfile
- All Superinterfaces:
Serializable
- All Known Implementing Classes:
DefaultUserProfile
Class for representing wiki user information, such as the login name, full
name, wiki name, and e-mail address. Note that since 2.6 the wiki name is
required to be automatically computed from the full name.
As of 2.8, user profiles can store custom key/value String/Serializable attributes, and store
a unique ID. Locks are checked by
AuthenticationManager
;
if a profile is locked, the user cannot log with that profile.- Since:
- 2.3
-
Method Summary
Modifier and TypeMethodDescriptionReturns the attributes associated with this profile as a Map of key/value pairs.Returns the creation date.getEmail()
Returns the user's e-mail address.Returns the user's full name.Returns the last-modified date.Returns the date/time of expiration of the profile's lock, if it has been previously locked viasetLockExpiry(Date)
and the lock is still active.Returns the user's login name.Returns the user password for use with custom authentication.getUid()
Returns the unique identifier for the user profile.Returns the user's wiki name, based on the full name with all whitespace removed.boolean
isLocked()
Returnstrue
if the profile is currently locked (disabled);false
otherwise.boolean
isNew()
Returnstrue
if the profile has never been saved before.void
setCreated
(Date date) Sets the created date.void
Sets the user's e-mail address.void
setFullname
(String arg) Sets the user's full name.void
setLastModified
(Date date) Sets the last-modified datevoid
setLockExpiry
(Date expiry) Locks the profile until a specified lock expiration date.void
setLoginName
(String name) Sets the name by which the user logs in.void
setPassword
(String arg) Sets the user's password for use with custom authentication.void
Sets the unique identifier for the user profile.toString()
Returns a string representation of this user profile.
-
Method Details
-
getAttributes
Returns the attributes associated with this profile as a Map of key/value pairs. The Map should generally be a "live" Map; changes to the keys or values will be reflected in the UserProfile.- Returns:
- the attributes
-
getCreated
Returns the creation date.- Returns:
- the creation date
-
getEmail
Returns the user's e-mail address.- Returns:
- the e-mail address
-
getFullname
Returns the user's full name.- Returns:
- the full name
-
getLastModified
Returns the last-modified date.- Returns:
- the date and time of last modification
-
getLockExpiry
Returns the date/time of expiration of the profile's lock, if it has been previously locked viasetLockExpiry(Date)
and the lock is still active. If the profile is unlocked, this method returnsnull
. Note that calling this method after the expiration date, even if had previously been set explicitly bysetLockExpiry(Date)
, will always returnnull.
- Returns:
- the lock expiration date
-
getLoginName
Returns the user's login name.- Returns:
- the login name
-
getPassword
Returns the user password for use with custom authentication. Note that the password field is not meaningful for container authentication; the user's private credentials are generally stored elsewhere. While it depends on theUserDatabase
implementation, in most cases the value returned by this method will be a password hash, not the password itself.- Returns:
- the password
-
getUid
Returns the unique identifier for the user profile. If not previously set, the value will benull
.- Returns:
- the unique ID.
-
getWikiName
Returns the user's wiki name, based on the full name with all whitespace removed.- Returns:
- the wiki name.
-
isLocked
boolean isLocked()Returnstrue
if the profile is currently locked (disabled);false
otherwise. By default, profiles are created unlocked. Strictly speaking, calling this method is equivalent to callinggetLockExpiry()
and, if it returns a non-null
value, checking if the date returned is later than the current time.- Returns:
- the result
-
isNew
boolean isNew()Returnstrue
if the profile has never been saved before. Implementing classes might check the last modified date, for example, to determine this.- Returns:
- whether the profile is new
-
setCreated
Sets the created date.- Parameters:
date
- the creation date
-
setEmail
Sets the user's e-mail address.- Parameters:
email
- the e-mail address
-
setFullname
Sets the user's full name. For example, "Janne Jalkanen."- Parameters:
arg
- the full name
-
setLastModified
Sets the last-modified date- Parameters:
date
- the last-modified date
-
setLockExpiry
Locks the profile until a specified lock expiration date.- Parameters:
expiry
- the date the lock expires; setting this value tonull
will cause the lock to be cleared.
-
setLoginName
Sets the name by which the user logs in. The login name is used as the username for custom authentication (seeAuthenticationManager.login(org.apache.wiki.api.core.Session, javax.servlet.http.HttpServletRequest, String, String)
,UserDatabaseLoginModule
). The login name is typically a short name ("jannej"). In contrast, the wiki name is typically of type FirstnameLastName ("JanneJalkanen").- Parameters:
name
- the login name
-
setPassword
Sets the user's password for use with custom authentication. It is not the responsibility of implementing classes to hash the password; that responsibility is borne by the UserDatabase implementation during save operations (seeUserDatabase.save(UserProfile)
). Note that the password field is not meaningful for container authentication; the user's private credentials are generally stored elsewhere.- Parameters:
arg
- the password
-
setUid
Sets the unique identifier for the user profile. Note that UserDatabase implementations are required not to change the unique identifier after the initial save.- Parameters:
uid
- the unique identifier to set
-
toString
Returns a string representation of this user profile.
-