MediaWiki  master
CentralIdLookup Class Reference

The CentralIdLookup service allows for connecting local users with cluster-wide IDs. More...

Inheritance diagram for CentralIdLookup:
Collaboration diagram for CentralIdLookup:

Public Member Functions

 centralIdFromLocalUser (User $user, $audience=self::AUDIENCE_PUBLIC, $flags=self::READ_NORMAL)
 Given a local User object, return the central ID. More...
 
 centralIdFromName ($name, $audience=self::AUDIENCE_PUBLIC, $flags=self::READ_NORMAL)
 Given a (local) user name, return the central ID. More...
 
 getProviderId ()
 
 isAttached (User $user, $wikiId=null)
 Check that a User is attached on the specified wiki. More...
 
 localUserFromCentralId ($id, $audience=self::AUDIENCE_PUBLIC, $flags=self::READ_NORMAL)
 Given a central user ID, return a local User object. More...
 
 lookupCentralIds (array $idToName, $audience=self::AUDIENCE_PUBLIC, $flags=self::READ_NORMAL)
 Given central user IDs, return the (local) user names. More...
 
 lookupUserNames (array $nameToId, $audience=self::AUDIENCE_PUBLIC, $flags=self::READ_NORMAL)
 Given (local) user names, return the central IDs. More...
 
 nameFromCentralId ($id, $audience=self::AUDIENCE_PUBLIC, $flags=self::READ_NORMAL)
 Given a central user ID, return the (local) user name. More...
 

Static Public Member Functions

static factory ($providerId=null)
 Fetch a CentralIdLookup. More...
 
static resetCache ()
 Reset internal cache for unit testing. More...
 

Public Attributes

const AUDIENCE_PUBLIC = 1
 
const AUDIENCE_RAW = 2
 
- Public Attributes inherited from IDBAccessObject
const READ_EXCLUSIVE = 7
 
const READ_LATEST = 1
 
const READ_LOCKING = 3
 
const READ_NONE = -1
 
const READ_NORMAL = 0
 

Protected Member Functions

 checkAudience ($audience)
 Check that the "audience" parameter is valid. More...
 

Private Attributes

string $providerId
 

Static Private Attributes

static CentralIdLookup[][] $instances = []
 

Detailed Description

The CentralIdLookup service allows for connecting local users with cluster-wide IDs.

Since
1.27

Definition at line 29 of file CentralIdLookup.php.

Member Function Documentation

CentralIdLookup::centralIdFromLocalUser ( User  $user,
  $audience = self::AUDIENCE_PUBLIC,
  $flags = self::READ_NORMAL 
)

Given a local User object, return the central ID.

Note
Unlike centralIdFromName(), this does guarantee that the local user is attached to the central account.
Parameters
User$userLocal user
int | User$audienceOne of the audience constants, or a specific user
int$flagsIDBAccessObject read flags
Returns
int User ID; 0 if the local user does not correspond to a central user, $audience lacks the rights needed to see it, or the central user isn't locally attached.

Definition at line 212 of file CentralIdLookup.php.

References $flags, centralIdFromName(), User\getName(), and isAttached().

CentralIdLookup::centralIdFromName (   $name,
  $audience = self::AUDIENCE_PUBLIC,
  $flags = self::READ_NORMAL 
)

Given a (local) user name, return the central ID.

Note
There's no requirement that the user name actually exists locally, or if it does that it's actually attached to the central account.
Parameters
string$nameCanonicalized user name
int | User$audienceOne of the audience constants, or a specific user
int$flagsIDBAccessObject read flags
Returns
int User ID; 0 if the name does not correspond to a user or $audience lacks the rights needed to see it.

Definition at line 170 of file CentralIdLookup.php.

References $flags, $name, and lookupUserNames().

Referenced by centralIdFromLocalUser().

CentralIdLookup::checkAudience (   $audience)
protected

Check that the "audience" parameter is valid.

Parameters
int | User$audienceOne of the audience constants, or a specific user
Returns
User|null User to check against, or null if no checks are needed
Exceptions
InvalidArgumentException

Definition at line 87 of file CentralIdLookup.php.

References User.

Referenced by LocalIdLookup\lookupCentralIds(), and LocalIdLookup\lookupUserNames().

CentralIdLookup::getProviderId ( )
final

Definition at line 77 of file CentralIdLookup.php.

References $providerId.

CentralIdLookup::isAttached ( User  $user,
  $wikiId = null 
)
abstract

Check that a User is attached on the specified wiki.

If unattached local accounts don't exist in your extension, this comes down to a check whether the central account exists at all and that $wikiId is using the same central database.

Parameters
User$user
string | null$wikiIdWiki to check attachment status. If null, check the current wiki.
Returns
bool

Referenced by centralIdFromLocalUser(), and localUserFromCentralId().

CentralIdLookup::localUserFromCentralId (   $id,
  $audience = self::AUDIENCE_PUBLIC,
  $flags = self::READ_NORMAL 
)

Given a central user ID, return a local User object.

Note
Unlike nameFromCentralId(), this does guarantee that the local user exists and is attached to the central account.
Parameters
int$idCentral user ID
int | User$audienceOne of the audience constants, or a specific user
int$flagsIDBAccessObject read flags
Returns
User|null Local user, or null if: $id doesn't correspond to a user, $audience lacks the rights needed to see the user, the user doesn't exist locally, or the user isn't locally attached.

Definition at line 188 of file CentralIdLookup.php.

References $flags, $name, $user, isAttached(), nameFromCentralId(), and User\newFromName().

CentralIdLookup::lookupCentralIds ( array  $idToName,
  $audience = self::AUDIENCE_PUBLIC,
  $flags = self::READ_NORMAL 
)
abstract

Given central user IDs, return the (local) user names.

Note
There's no requirement that the user names actually exist locally, or if they do that they're actually attached to the central account.
Parameters
array$idToNameArray with keys being central user IDs
int | User$audienceOne of the audience constants, or a specific user
int$flagsIDBAccessObject read flags
Returns
array Copy of $idToName with values set to user names (or empty-string if the user exists but $audience lacks the rights needed to see it). IDs not corresponding to a user are unchanged.

Referenced by nameFromCentralId().

CentralIdLookup::lookupUserNames ( array  $nameToId,
  $audience = self::AUDIENCE_PUBLIC,
  $flags = self::READ_NORMAL 
)
abstract

Given (local) user names, return the central IDs.

Note
There's no requirement that the user names actually exist locally, or if they do that they're actually attached to the central account.
Parameters
array$nameToIdArray with keys being canonicalized user names
int | User$audienceOne of the audience constants, or a specific user
int$flagsIDBAccessObject read flags
Returns
array Copy of $nameToId with values set to central IDs. Names not corresponding to a user (or $audience lacks the rights needed to see it) are unchanged.

Referenced by centralIdFromName().

CentralIdLookup::nameFromCentralId (   $id,
  $audience = self::AUDIENCE_PUBLIC,
  $flags = self::READ_NORMAL 
)

Given a central user ID, return the (local) user name.

Note
There's no requirement that the user name actually exists locally, or if it does that it's actually attached to the central account.
Parameters
int$idCentral user ID
int | User$audienceOne of the audience constants, or a specific user
int$flagsIDBAccessObject read flags
Returns
string|null User name, or empty string if $audience lacks the rights needed to see it, or null if $id doesn't correspond to a user

Definition at line 153 of file CentralIdLookup.php.

References $flags, and lookupCentralIds().

Referenced by localUserFromCentralId().

static CentralIdLookup::resetCache ( )
static

Reset internal cache for unit testing.

Definition at line 70 of file CentralIdLookup.php.

Referenced by BotPasswordTest\setUp().

Member Data Documentation

CentralIdLookup [][] CentralIdLookup::$instances = []
staticprivate

Definition at line 35 of file CentralIdLookup.php.

string CentralIdLookup::$providerId
private

Definition at line 38 of file CentralIdLookup.php.

Referenced by factory(), and getProviderId().

const CentralIdLookup::AUDIENCE_PUBLIC = 1

Definition at line 31 of file CentralIdLookup.php.

Referenced by CentralIdLookupTest\testCheckAudience().


The documentation for this class was generated from the following file: