This is a virtual base class (a.k.a an interface) for all user mappers. It is
not useable as a mapping in TWiki - use the BaseUserMapping for default
behaviour.
User mapping is the process by which TWiki maps from a username (a login name)
to a display name and back. It is also where groups are maintained.
See TWiki::Users::BaseUserMapping and TWiki::Users::TWikiUserMapping for
the default implementations of this interface.
If you want to write a user mapper, you will need to implement the methods
described in this class.
User mappings work by mapping both login names and display names to a
canonical user id. This user id is composed from a prefix that defines
the mapper in use (something like 'BaseUserMapping_' or 'LdapUserMapping_')
and a unique user id that the mapper uses to identify the user.
The null prefix is reserver for the TWikiUserMapping for compatibility
with old TWiki releases.
Note: in all the following documentation, $user refers to a
canonical user id.
Called by the TWiki::Users object to determine which loaded mapping
to use for a given user (must be fast).
Default is false
ObjectMethod *getCanonicalUserID ($login,$dontcheck) -> cUID
Convert a login name to the corresponding canonical user name. The
canonical name can be any string of 7-bit alphanumeric and underscore
characters, and must correspond 1:1 to the login name.
(undef on failure)
(if dontcheck is true, return a cUID for a nonexistant user too - used for registration)
Subclasses must implement this method.
Converts an internal cUID to that user's login
(undef on failure)
Subclasses must implement this method.
ObjectMethodaddUser($login,$wikiname,$password,$emails) -> cUID
Add a user to the persistant mapping that maps from usernames to wikinames
and vice-versa, via a canonical user id (cUID).
$login and $wikiname must be acceptable to $TWiki::cfg{NameFilter}.
$login must always be specified. $wikiname may be undef, in which case
the user mapper should make one up.
This function must return a canonical user id that it uses to uniquely
identify the user. This can be the login name, or the wikiname if they
are all guaranteed unigue, or some other string consisting only of 7-bit
alphanumerics and underscores.
If you fail to create a new user (for eg your Mapper has read only access),
throw Error::Simple('Failed to add user: '.$error);
where $error is a descriptive string.
Throws an Error::Simple if user adding is not supported (the default).
Determine if the user already exists or not. Whether a user exists
or not is determined by the password manager.
Subclasses must implement this method.
Return a list of canonical user names for the users that have this email
registered with the password manager or the user mapping manager.
Returns an empty list by default.
If this is a user, return their email addresses. If it is a group,
return the addresses of everyone in the group.
Duplicates should be removed from the list.
By default, returns the empty list.
If the $oldPassU matches matches the user's password, then it will
replace it with $newPassU.
If $oldPassU is not correct and not 1, will return 0.
If $oldPassU is 1, will force the change irrespective of
the existing password, adding the user if necessary.
Otherwise returns 1 on success, undef on failure.
Default behaviour is to fail.
Returns a string indicating the error that happened in the password handlers
TODO: these delayed errors should be replaced with Exceptions.
returns undef if no error 9the default)