MediaWiki REL1_37
DoubleRedirectJob Class Reference

Job to fix double redirects after moving a page. More...

Inheritance diagram for DoubleRedirectJob:
Collaboration diagram for DoubleRedirectJob:

Public Member Functions

 __construct (PageReference $page, array $params)
 
 run ()
 
- Public Member Functions inherited from Job
 __construct ( $command, $params=null)
 
 allowRetries ()
 
Returns
bool Whether this job can be retried on failure by job runners
Since
1.21

 
 getDeduplicationInfo ()
 Subclasses may need to override this to make duplication detection work.
 
 getLastError ()
 
Returns
string

 
 getMetadata ( $field=null)
 
 getParams ()
 
Returns
array Parameters that specify sources, targets, and options for execution

 
 getQueuedTimestamp ()
 
 getReadyTimestamp ()
 
Returns
int|null UNIX timestamp of when the job was runnable, or null
Since
1.26

 
 getReleaseTimestamp ()
 
 getRequestId ()
 
Returns
string|null Id of the request that created this job. Follows jobs recursively, allowing to track the id of the request that started a job when jobs insert jobs which insert other jobs.
Since
1.27

 
 getRootJobParams ()
 
 getTitle ()
 
 getType ()
 
Returns
string Job type that defines what sort of changes this job makes

 
 hasExecutionFlag ( $flag)
 
Parameters
int$flagJOB_* class constant
Returns
bool
Since
1.31

 
 hasRootJobParams ()
 
 ignoreDuplicates ()
 Whether the queue should reject insertion of this job if a duplicate exists.
 
 isRootJob ()
 
 setMetadata ( $field, $value)
 
 teardown ( $status)
 
 toString ()
 
Returns
string Debugging string describing the job

 
 workItemCount ()
 
- Public Member Functions inherited from RunnableJob
 tearDown ( $status)
 Do any final cleanup after run(), deferred updates, and all DB commits happen.
 

Static Public Member Functions

static fixRedirects ( $reason, $redirTitle)
 Insert jobs into the job queue to fix redirects to the given title.
 
static getFinalDestination ( $title)
 Get the final destination of a redirect.
 
- Static Public Member Functions inherited from Job
static factory ( $command, $params=[])
 Create the appropriate object to handle a specific job.
 
static newRootJobParams ( $key)
 Get "root job" parameters for a task.
 

Private Member Functions

 getUser ()
 Get a user object for doing edits, from a request-lifetime cache False will be returned if the user name specified in the 'double-redirect-fixer' message is invalid.
 

Private Attributes

Title $redirTitle
 The title which has changed, redirects pointing to this title are fixed.
 

Static Private Attributes

static User $user
 

Additional Inherited Members

- Public Attributes inherited from Job
string $command
 
array $metadata = []
 Additional queue metadata.
 
array $params
 Array of job parameters.
 
- Protected Member Functions inherited from Job
 addTeardownCallback ( $callback)
 
 setLastError ( $error)
 
- Protected Attributes inherited from Job
string $error
 Text for error that occurred last.
 
int $executionFlags = 0
 Bitfield of JOB_* class constants.
 
bool $removeDuplicates = false
 Expensive jobs may set this to true.
 
callable[] $teardownCallbacks = []
 
Title $title
 

Detailed Description

Job to fix double redirects after moving a page.

Definition at line 36 of file DoubleRedirectJob.php.

Constructor & Destructor Documentation

◆ __construct()

DoubleRedirectJob::__construct ( PageReference  $page,
array  $params 
)
Parameters
PageReference$page
array$paramsExpected to contain these elements:
  • 'redirTitle' => string The title that changed and should be fixed.
  • 'reason' => string Reason for the change, can be "move" or "maintenance". Used as a suffix for the message keys "double-redirect-fixed-move" and "double-redirect-fixed-maintenance". ]

Definition at line 55 of file DoubleRedirectJob.php.

References Job\$params.

Member Function Documentation

◆ fixRedirects()

static DoubleRedirectJob::fixRedirects (   $reason,
  $redirTitle 
)
static

Insert jobs into the job queue to fix redirects to the given title.

Parameters
string$reasonThe reason for the fix, see message "double-redirect-fixed-<reason>"
LinkTarget$redirTitleThe title which has changed, redirects pointing to this title are fixed

Definition at line 67 of file DoubleRedirectJob.php.

References $redirTitle, $res, Job\$title, DB_PRIMARY, Title\getDBkey(), Title\getNamespace(), and wfGetDB().

Referenced by MovePageForm\doSubmit().

◆ getFinalDestination()

static DoubleRedirectJob::getFinalDestination (   $title)
static

Get the final destination of a redirect.

Parameters
LinkTarget$title
Returns
Title|bool The final Title after following all redirects, or false if the page is not a redirect or the redirect loops.

Definition at line 197 of file DoubleRedirectJob.php.

References Job\$title, DB_PRIMARY, Title\getDBkey(), Title\getNamespace(), Title\isExternal(), wfDebug(), and wfGetDB().

Referenced by run().

◆ getUser()

DoubleRedirectJob::getUser ( )
private

Get a user object for doing edits, from a request-lifetime cache False will be returned if the user name specified in the 'double-redirect-fixer' message is invalid.

Returns
User|bool

Definition at line 252 of file DoubleRedirectJob.php.

References $user, User\newFromName(), and wfMessage().

Referenced by run().

◆ run()

DoubleRedirectJob::run ( )

Member Data Documentation

◆ $redirTitle

Title DoubleRedirectJob::$redirTitle
private

The title which has changed, redirects pointing to this title are fixed.

Definition at line 41 of file DoubleRedirectJob.php.

Referenced by fixRedirects().

◆ $user

User DoubleRedirectJob::$user
staticprivate

Definition at line 44 of file DoubleRedirectJob.php.

Referenced by getUser(), and run().


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