MediaWiki REL1_37
|
Maintenance script that checks for articles to fix after adding/deleting namespaces. More...
Public Member Functions | |
__construct () | |
Default constructor. | |
execute () | |
Do the actual work. | |
Public Member Functions inherited from Maintenance | |
checkRequiredExtensions () | |
Verify that the required extensions are installed. | |
cleanupChanneled () | |
Clean up channeled output. | |
clearParamsAndArgs () | |
Clear all params and arguments. | |
finalSetup () | |
Handle some last-minute setup here. | |
getConfig () | |
getDbType () | |
Does the script need different DB access? By default, we give Maintenance scripts normal rights to the DB. | |
getName () | |
Get the script's name. | |
globals () | |
Potentially debug globals. | |
isQuiet () | |
loadParamsAndArgs ( $self=null, $opts=null, $args=null) | |
Process command line arguments $mOptions becomes an array with keys set to the option names $mArgs becomes a zero-based array containing the non-option arguments. | |
loadSettings () | |
Generic setup for most installs. | |
loadWithArgv ( $argv) | |
Load params and arguments from a given array of command-line arguments. | |
memoryLimit () | |
Normally we disable the memory_limit when running admin scripts. | |
outputChanneled ( $msg, $channel=null) | |
Message outputter with channeled message support. | |
purgeRedundantText ( $delete=true) | |
Support function for cleaning up redundant text records. | |
runChild ( $maintClass, $classFile=null) | |
Run a child maintenance script. | |
setAgentAndTriggers () | |
This method used to be for internal use by doMaintenance.php to apply some optional global state to LBFactory for debugging purposes. | |
setConfig (Config $config) | |
setDB (IMaintainableDatabase $db) | |
Sets database object to be returned by getDB(). | |
setup () | |
Do some sanity checking and basic setup. | |
shutdown () | |
Call before shutdown to run any deferred updates. | |
validateParamsAndArgs () | |
Run some validation checks on the params, etc. | |
Protected Attributes | |
IMaintainableDatabase | $db |
Protected Attributes inherited from Maintenance | |
bool | $mAllowUnregisteredOptions = false |
Allow arbitrary options to be passed, or only specified ones? | |
array | $mArgList = [] |
Desired/allowed args. | |
array | $mArgs = [] |
This is the list of arguments that were actually passed. | |
int null | $mBatchSize = null |
Batch size. | |
$mDbPass | |
$mDbUser | |
string | $mDescription = '' |
A description of the script, children should change this via addDescription() | |
bool | $mInputLoaded = false |
Have we already loaded our user input? | |
array | $mOptions = [] |
This is the list of options that were actually passed. | |
array[] | $mParams = [] |
Array of desired/allowed params. | |
bool | $mQuiet = false |
Special vars for params that are always used. | |
string null | $mSelf |
Name of the script currently running. | |
array | $mShortParamsMap = [] |
Mapping short parameters to long ones. | |
Private Member Functions | |
canMerge ( $id, LinkTarget $linkTarget, &$logStatus) | |
Determine if we can merge a page. | |
checkAll ( $options) | |
Check all namespaces. | |
checkLinkTable ( $table, $fieldPrefix, $ns, $name, $options, $extraConds=[]) | |
Check and repair the destination fields in a link table. | |
checkNamespace ( $ns, $name, $options) | |
Check a given prefix and try to move it into the given destination namespace. | |
checkPrefix ( $options) | |
Move the given pseudo-namespace, either replacing the colon with a hyphen (useful for pseudo-namespaces that conflict with interwiki links) or move them to another namespace if specified. | |
getAlternateTitle (LinkTarget $linkTarget, $options) | |
Get an alternative title to move a page to. | |
getDestinationTitle ( $ns, $name, $sourceNs, $sourceDbk) | |
Get the preferred destination title for a given target page. | |
getInterwikiList () | |
getTargetList ( $ns, $name, $options) | |
Find pages in main and talk namespaces that have a prefix of the new namespace so we know titles that will need migrating. | |
mergePage ( $row, Title $newTitle) | |
Merge page histories. | |
movePage ( $id, LinkTarget $newLinkTarget) | |
Move a page. | |
Private Attributes | |
int | $deletedLinks = 0 |
Total number of links deleted because they weren't automatically resolveable due to the target already existing. | |
int | $resolvableLinks = 0 |
Total number of links that need fixing that are automatically resolveable. | |
int | $resolvablePages = 0 |
Total number of pages that need fixing that are automatically resolveable. | |
int | $totalLinks = 0 |
Total number of erroneous links. | |
int | $totalPages = 0 |
Total number of pages that need fixing. | |
Additional Inherited Members | |
Static Public Member Functions inherited from Maintenance | |
static | getTermSize () |
Get the terminal size as a two-element array where the first element is the width (number of columns) and the second element is the height (number of rows). | |
static | posix_isatty ( $fd) |
Wrapper for posix_isatty() We default as considering stdin a tty (for nice readline methods) but treating stout as not a tty to avoid color codes. | |
static | readconsole ( $prompt='> ') |
Prompt the console for input. | |
static | requireTestsAutoloader () |
Call this to set up the autoloader to allow classes to be used from the tests directory. | |
static | shouldExecute () |
Should we execute the maintenance script, or just allow it to be included as a standalone class? It checks that the call stack only includes this function and "requires" (meaning was called from the file scope) | |
Public Attributes inherited from Maintenance | |
resource null | $fileHandle |
Used when creating separate schema files. | |
array | $orderedOptions = [] |
Used to read the options in the order they were passed. | |
const | DB_ADMIN = 2 |
const | DB_NONE = 0 |
Constants for DB access type. | |
const | DB_STD = 1 |
const | STDIN_ALL = -1 |
Protected Member Functions inherited from Maintenance | |
activateProfiler () | |
Activate the profiler (assuming $wgProfiler is set) | |
addArg ( $arg, $description, $required=true) | |
Add some args that are needed. | |
addDefaultParams () | |
Add the default parameters to the scripts. | |
addDescription ( $text) | |
Set the description text. | |
addOption ( $name, $description, $required=false, $withArg=false, $shortName=false, $multiOccurrence=false) | |
Add a parameter to the script. | |
adjustMemoryLimit () | |
Adjusts PHP's memory limit to better suit our needs, if needed. | |
afterFinalSetup () | |
Execute a callback function at the end of initialisation. | |
beginTransaction (IDatabase $dbw, $fname) | |
Begin a transaction on a DB. | |
commitTransaction (IDatabase $dbw, $fname) | |
Commit the transaction on a DB handle and wait for replica DBs to catch up. | |
countDown ( $seconds) | |
Count down from $seconds to zero on the terminal, with a one-second pause between showing each number. | |
deleteOption ( $name) | |
Remove an option. | |
error ( $err, $die=0) | |
Throw an error to the user. | |
fatalError ( $msg, $exitCode=1) | |
Output a message and terminate the current script. | |
getArg ( $argId=0, $default=null) | |
Get an argument. | |
getBatchSize () | |
Returns batch size. | |
getDB ( $db, $groups=[], $dbDomain=false) | |
Returns a database to be used by current maintenance script. | |
getDir () | |
Get the maintenance directory. | |
getHookContainer () | |
Get a HookContainer, for running extension hooks or for hook metadata. | |
getHookRunner () | |
Get a HookRunner for running core hooks. | |
getOption ( $name, $default=null) | |
Get an option, or return the default. | |
getStdin ( $len=null) | |
Return input from stdin. | |
hasArg ( $argId=0) | |
Does a given argument exist? | |
hasOption ( $name) | |
Checks to see if a particular option was set. | |
loadSpecialVars () | |
Handle the special variables that are global to all scripts. | |
maybeHelp ( $force=false) | |
Maybe show the help. | |
output ( $out, $channel=null) | |
Throw some output to the user. | |
parseIntList ( $text) | |
Utility function to parse a string (perhaps from a command line option) into a list of integers (perhaps some kind of numeric IDs). | |
requireExtension ( $name) | |
Indicate that the specified extension must be loaded before the script can run. | |
rollbackTransaction (IDatabase $dbw, $fname) | |
Rollback the transaction on a DB handle. | |
setAllowUnregisteredOptions ( $allow) | |
Sets whether to allow unregistered options, which are options passed to a script that do not match an expected parameter. | |
setBatchSize ( $s=0) | |
showHelp () | |
Definitely show the help. | |
supportsOption ( $name) | |
Checks to see if a particular option in supported. | |
validateUserOption ( $errorMsg) | |
waitForReplication () | |
Wait for replica DBs to catch up. | |
Maintenance script that checks for articles to fix after adding/deleting namespaces.
Definition at line 41 of file namespaceDupes.php.
NamespaceDupes::__construct | ( | ) |
Default constructor.
Children should call this first if implementing their own constructors
Reimplemented from Maintenance.
Definition at line 79 of file namespaceDupes.php.
References Maintenance\addDescription(), and Maintenance\addOption().
|
private |
Determine if we can merge a page.
We check if an inaccessible revision would become the latest and deny the merge if so – it's theoretically possible to update the latest revision, but opens a can of worms – search engine updates, recentchanges review, etc.
int | $id | The page_id |
LinkTarget | $linkTarget | The new link target |
string | &$logStatus | This is set to the log status message on failure |
Definition at line 618 of file namespaceDupes.php.
Referenced by checkNamespace().
|
private |
Check all namespaces.
array | $options | Associative array of validated command-line options |
Definition at line 131 of file namespaceDupes.php.
References checkLinkTable(), checkNamespace(), Maintenance\getConfig(), getInterwikiList(), and Maintenance\output().
Referenced by execute().
|
private |
Check and repair the destination fields in a link table.
string | $table | The link table name |
string | $fieldPrefix | The field prefix in the link table |
int | $ns | Destination namespace id |
string | $name | |
array | $options | Associative array of validated command-line options |
array | $extraConds | Extra conditions for the SQL query |
Definition at line 356 of file namespaceDupes.php.
References $res, DB_PRIMARY, getDB(), getDestinationTitle(), and Maintenance\output().
Referenced by checkAll().
|
private |
Check a given prefix and try to move it into the given destination namespace.
int | $ns | Destination namespace id |
string | $name | |
array | $options | Associative array of validated command-line options |
Definition at line 261 of file namespaceDupes.php.
References canMerge(), getAlternateTitle(), getDestinationTitle(), getTargetList(), mergePage(), movePage(), and Maintenance\output().
Referenced by checkAll(), and checkPrefix().
|
private |
Move the given pseudo-namespace, either replacing the colon with a hyphen (useful for pseudo-namespaces that conflict with interwiki links) or move them to another namespace if specified.
array | $options | Associative array of validated command-line options |
Definition at line 469 of file namespaceDupes.php.
References checkNamespace(), and Maintenance\output().
Referenced by execute().
NamespaceDupes::execute | ( | ) |
Do the actual work.
All child classes will need to implement this
Reimplemented from Maintenance.
Definition at line 100 of file namespaceDupes.php.
References checkAll(), checkPrefix(), Maintenance\getOption(), Maintenance\hasOption(), and Maintenance\output().
|
private |
Get an alternative title to move a page to.
This is used if the preferred destination title already exists.
LinkTarget | $linkTarget | |
array | $options | Associative array of validated command-line options |
Definition at line 548 of file namespaceDupes.php.
References $title, MediaWiki\Linker\LinkTarget\getDBkey(), and MediaWiki\Linker\LinkTarget\getNamespace().
Referenced by checkNamespace().
|
private |
Get the preferred destination title for a given target page.
int | $ns | The destination namespace ID |
string | $name | The conflicting prefix |
int | $sourceNs | The source namespace |
int | $sourceDbk | The source DB key (i.e. page_title) |
Definition at line 521 of file namespaceDupes.php.
References NS_TALK.
Referenced by checkLinkTable(), and checkNamespace().
|
private |
|
private |
Find pages in main and talk namespaces that have a prefix of the new namespace so we know titles that will need migrating.
int | $ns | Destination namespace id |
string | $name | Prefix that is being made a namespace |
array | $options | Associative array of validated command-line options |
Definition at line 487 of file namespaceDupes.php.
References DB_PRIMARY, getDB(), NS_MAIN, and NS_TALK.
Referenced by checkNamespace().
|
private |
Merge page histories.
Definition at line 639 of file namespaceDupes.php.
References Maintenance\beginTransaction(), Maintenance\commitTransaction(), DB_PRIMARY, Title\getArticleID(), and getDB().
Referenced by checkNamespace().
|
private |
Move a page.
int | $id | The page_id |
LinkTarget | $newLinkTarget | The new title link target |
Definition at line 573 of file namespaceDupes.php.
References DB_PRIMARY, getDB(), MediaWiki\Linker\LinkTarget\getDBkey(), and MediaWiki\Linker\LinkTarget\getNamespace().
Referenced by checkNamespace().
|
protected |
Definition at line 46 of file namespaceDupes.php.
|
private |
Total number of links deleted because they weren't automatically resolveable due to the target already existing.
Definition at line 77 of file namespaceDupes.php.
|
private |
Total number of links that need fixing that are automatically resolveable.
Definition at line 64 of file namespaceDupes.php.
|
private |
Total number of pages that need fixing that are automatically resolveable.
Definition at line 52 of file namespaceDupes.php.
|
private |
Total number of erroneous links.
Definition at line 70 of file namespaceDupes.php.
|
private |
Total number of pages that need fixing.
Definition at line 58 of file namespaceDupes.php.