Manual:$wgWhitelistReadRegexp/en
<translate> User rights, access control and monitoring</translate>: $wgWhitelistReadRegexp | |
---|---|
Whitelists publicly readable titles with regular expressions. |
|
<translate> Introduced in version:</translate> | 1.21.0 (Gerrit change 11137; git #550b878e) |
<translate> Removed in version:</translate> | <translate> still in use</translate> |
<translate> Allowed values:</translate> | (Array of regexes) or false |
<translate> Default value:</translate> | false |
<translate> Other settings:</translate> <translate> Alphabetical</translate> | <translate> By function</translate> |
Details
It is similar to $wgWhitelistRead
, but uses a list of regular expressions.
This would be useful in a semi-public team wiki situation where one would want to hide everything except for an entire namespace from everyone.
This function will match the regexp against the title name, which is without underscore. Unless ^
and/or $
is specified, a regular expression might match pages not intended to be whitelisted.
This configuration parameter will only work if the following is set:
$wgGroupPermissions['*']['read'] = false;
Otherwise, all pages are accessible, regardless of this setting.
Examples
Whitelist "Main Page" or "Security Main Page":
$wgWhitelistReadRegexp = [ '/Main Page/' ];
Allow reading any page starting with 'User' regardless of the case, e.g. "User is banned" and "User:JohnDoe":
$wgWhitelistReadRegexp = [ '@^UsEr.*@i' ];
Allow reading "Main Page" and all pages in namespace "Foo Bar":
$wgWhitelistReadRegexp = [
'/Main Page/',
'/^Foo Bar:/'
];
You can also create a blacklist with this by using a negative lookahead containing all blacklisted terms in the same expression. This will block the namespaces "Private" and "Private talk", and also block subpages in the "User" namespace, but make all other pages public:
$wgWhitelistReadRegexp = [ "#(?!(?:Private(?: talk)?:|User:[^/]+/.))^#" ];