MediaWiki 1.39.10
|
Configuration holder, particularly for multi-wiki sites. More...
Public Member Functions | |
extractAllGlobals ( $wiki, $site=null, $params=[], $wikiTags=[]) | |
Retrieves the values of all settings, and places them in their corresponding global variables. | |
extractGlobal ( $setting, $wiki, $site=null, $params=[], $wikiTags=[]) | |
Retrieves the value of a given setting, and places it in its corresponding global variable. | |
extractGlobalSetting ( $setting, $wiki, $params) | |
extractVar ( $setting, $wiki, $site, &$var, $params=[], $wikiTags=[]) | |
Retrieves the value of a given setting, and places it in a variable passed by reference. | |
get ( $settingName, $wiki, $site=null, $params=[], $wikiTags=[]) | |
Retrieves a configuration setting for a given wiki. | |
getAll ( $wiki, $site=null, $params=[], $wikiTags=[]) | |
Gets all settings for a wiki. | |
getBool ( $setting, $wiki, $site=null, $wikiTags=[]) | |
Retrieves a configuration setting for a given wiki, forced to a boolean. | |
getConfig ( $wiki, $settings) | |
Get the resolved (post-setup) configuration of a potentially foreign wiki. | |
getLocalDatabases () | |
Retrieves an array of local databases. | |
loadFullData () | |
siteFromDB ( $wiki) | |
Work out the site and language name from a database name. | |
Public Attributes | |
string array | $fullLoadCallback = null |
Optional callback to load full configuration data. | |
$fullLoadDone = false | |
Whether or not all data has been loaded. | |
$settings = [] | |
The whole array of settings. | |
callable null | $siteParamsCallback = null |
A callback function that returns an array with the following keys (all optional): | |
$suffixes = [] | |
Array of suffixes, for self::siteFromDB() | |
$wikis = [] | |
Array of wikis, should be the same as $wgLocalDatabases. | |
Protected Member Functions | |
getWikiParams ( $wiki) | |
Return specific settings for $wiki See the documentation of self::$siteParamsCallback for more in-depth documentation about this function. | |
mergeParams ( $wiki, $site, array $params, array $wikiTags) | |
Merge params between the ones passed to the function and the ones given by self::$siteParamsCallback for backward compatibility Values returned by self::getWikiParams() have the priority. | |
Protected Attributes | |
array | $cfgCache = [] |
Configuration cache for getConfig() | |
Configuration holder, particularly for multi-wiki sites.
A basic synopsis:
Consider a wikifarm having three sites: two production sites, one in English and one in German, and one testing site. You can assign them easy-to-remember identifiers - ISO 639 codes 'en' and 'de' for language wikis, and 'beta' for the testing wiki.
You would thus initialize the site configuration by specifying the wiki identifiers:
When configuring the MediaWiki global settings (the $wg variables), the identifiers will be available to specify settings on a per wiki basis.
With three wikis, that is easy to manage. But what about a farm with hundreds of wikis? Site configuration provides a special keyword named 'default' which is the value used when a wiki is not found. Hence the above code could be written:
Since settings can contain arrays, site configuration provides a way to merge an array with the default. This is very useful to avoid repeating settings again and again while still maintaining specific changes on a per wiki basis.
Finally, to load all configuration settings, extract them in global context:
Simple suffix system where "pt_brwiki" becomes lang="pt-br", site="wiki":
Suffix is resolved as an alias, so "dewiki" becomes lang="de", site="wikipedia":
Definition at line 126 of file SiteConfiguration.php.
SiteConfiguration::extractAllGlobals | ( | $wiki, | |
$site = null, | |||
$params = [], | |||
$wikiTags = [] ) |
Retrieves the values of all settings, and places them in their corresponding global variables.
string | $wiki | Wiki ID of the wiki in question. |
string | null | $site | The site from siteFromDB(), or db suffix. |
array | $params | List of parameters. $.'key' is replaced by $value in all returned data. |
array | $wikiTags | The tags assigned to the wiki. |
Definition at line 434 of file SiteConfiguration.php.
References extractGlobalSetting(), and mergeParams().
SiteConfiguration::extractGlobal | ( | $setting, | |
$wiki, | |||
$site = null, | |||
$params = [], | |||
$wikiTags = [] ) |
Retrieves the value of a given setting, and places it in its corresponding global variable.
string | $setting | ID of the setting name to retrieve |
string | $wiki | Wiki ID of the wiki in question. |
string | null | $site | The site from siteFromDB(), or db suffix. |
array | $params | List of parameters. $.'key' is replaced by $value in all returned data. |
array | $wikiTags | The tags assigned to the wiki. |
Definition at line 393 of file SiteConfiguration.php.
References extractGlobalSetting(), and mergeParams().
SiteConfiguration::extractGlobalSetting | ( | $setting, | |
$wiki, | |||
$params ) |
string | $setting | |
string | $wiki | |
array | $params |
Definition at line 405 of file SiteConfiguration.php.
Referenced by extractAllGlobals(), and extractGlobal().
SiteConfiguration::extractVar | ( | $setting, | |
$wiki, | |||
$site, | |||
& | $var, | ||
$params = [], | |||
$wikiTags = [] ) |
Retrieves the value of a given setting, and places it in a variable passed by reference.
string | $setting | ID of the setting name to retrieve |
string | $wiki | Wiki ID of the wiki in question. |
string | null | $site | The site from siteFromDB(), or db suffix. |
array | &$var | Reference The variable to insert the value into. |
array | $params | List of parameters. $.'key' is replaced by $value in all returned data. |
array | $wikiTags | The tags assigned to the wiki. |
Definition at line 376 of file SiteConfiguration.php.
SiteConfiguration::get | ( | $settingName, | |
$wiki, | |||
$site = null, | |||
$params = [], | |||
$wikiTags = [] ) |
Retrieves a configuration setting for a given wiki.
string | $settingName | ID of the setting name to retrieve |
string | $wiki | Wiki ID of the wiki in question. |
string | null | $site | The site from siteFromDB(), or db suffix. |
array | $params | List of parameters. $.'key' is replaced by $value in all returned data. |
array | $wikiTags | The tags assigned to the wiki. |
Definition at line 186 of file SiteConfiguration.php.
References mergeParams().
SiteConfiguration::getAll | ( | $wiki, | |
$site = null, | |||
$params = [], | |||
$wikiTags = [] ) |
Gets all settings for a wiki.
string | $wiki | Wiki ID of the wiki in question. |
string | null | $site | The site from siteFromDB(), or db suffix. |
array | $params | List of parameters. $.'key' is replaced by $value in all returned data. |
array | $wikiTags | The tags assigned to the wiki. |
Definition at line 314 of file SiteConfiguration.php.
References mergeParams().
SiteConfiguration::getBool | ( | $setting, | |
$wiki, | |||
$site = null, | |||
$wikiTags = [] ) |
Retrieves a configuration setting for a given wiki, forced to a boolean.
string | $setting | ID of the setting name to retrieve |
string | $wiki | Wiki ID of the wiki in question. |
string | null | $site | The site from siteFromDB(), or db suffix. |
array | $wikiTags | The tags assigned to the wiki. |
Definition at line 354 of file SiteConfiguration.php.
SiteConfiguration::getConfig | ( | $wiki, | |
$settings ) |
Get the resolved (post-setup) configuration of a potentially foreign wiki.
For foreign wikis, this is expensive, and only works if maintenance scripts are setup to handle the –wiki parameter such as in wiki farms.
string | $wiki | |
string | string[] | $settings | A setting name or array of setting names |
MWException |
Definition at line 564 of file SiteConfiguration.php.
References $res, $settings, and unserialize().
SiteConfiguration::getLocalDatabases | ( | ) |
Retrieves an array of local databases.
Definition at line 363 of file SiteConfiguration.php.
References $wikis.
|
protected |
Return specific settings for $wiki See the documentation of self::$siteParamsCallback for more in-depth documentation about this function.
string | $wiki |
Definition at line 451 of file SiteConfiguration.php.
References $siteParamsCallback.
Referenced by mergeParams(), and siteFromDB().
SiteConfiguration::loadFullData | ( | ) |
Definition at line 657 of file SiteConfiguration.php.
References $fullLoadCallback.
|
protected |
Merge params between the ones passed to the function and the ones given by self::$siteParamsCallback for backward compatibility Values returned by self::getWikiParams() have the priority.
string | $wiki | Wiki ID of the wiki in question. |
string | null | $site | The site from siteFromDB(), or db suffix. |
array | $params | List of parameters. $.'key' is replaced by $value in all returned data. |
array | $wikiTags | The tags assigned to the wiki. |
Definition at line 490 of file SiteConfiguration.php.
References getWikiParams().
Referenced by extractAllGlobals(), extractGlobal(), get(), and getAll().
SiteConfiguration::siteFromDB | ( | $wiki | ) |
Work out the site and language name from a database name.
string | $wiki | Wiki ID |
Definition at line 532 of file SiteConfiguration.php.
References getWikiParams().
|
protected |
Configuration cache for getConfig()
Definition at line 175 of file SiteConfiguration.php.
string array SiteConfiguration::$fullLoadCallback = null |
Optional callback to load full configuration data.
Definition at line 150 of file SiteConfiguration.php.
Referenced by loadFullData().
SiteConfiguration::$fullLoadDone = false |
Whether or not all data has been loaded.
Definition at line 153 of file SiteConfiguration.php.
SiteConfiguration::$settings = [] |
The whole array of settings.
If the key "@replaceableSettings" exists, it contains a list of setting names that are subject to string replacement of $params.
Definition at line 144 of file SiteConfiguration.php.
Referenced by getConfig().
callable null SiteConfiguration::$siteParamsCallback = null |
A callback function that returns an array with the following keys (all optional):
Definition at line 169 of file SiteConfiguration.php.
Referenced by getWikiParams().
SiteConfiguration::$suffixes = [] |
Array of suffixes, for self::siteFromDB()
Definition at line 131 of file SiteConfiguration.php.
SiteConfiguration::$wikis = [] |
Array of wikis, should be the same as $wgLocalDatabases.
Definition at line 136 of file SiteConfiguration.php.
Referenced by getLocalDatabases().