MediaWiki REL1_39
McrUndoAction Class Reference

Temporary action for MCR undos. More...

Inheritance diagram for McrUndoAction:
Collaboration diagram for McrUndoAction:

Public Member Functions

 __construct (Page $page, IContextSource $context, ReadOnlyMode $readOnlyMode, RevisionLookup $revisionLookup, RevisionRenderer $revisionRenderer, Config $config)
 
 getDescription ()
 Returns the description that goes below the <h1> element.
 
 getName ()
 Return the name of the action this object responds to.
 
 getRestriction ()
 Get the permission required to perform this action.
 
 onSubmit ( $data)
 Process the form on POST submission.
 
 onSuccess ()
 Do something exciting on successful processing of the form.
 
 show ()
 The basic pattern for actions is to display some sort of HTMLForm UI, maybe with some stuff underneath (history etc); to do some processing on submission of that form (delete, protect, etc) and to do something exciting on 'success', be that display something new or redirect to somewhere.
 
- Public Member Functions inherited from FormAction
 doesWrites ()
 
- Public Member Functions inherited from Action
 __construct (Page $page, IContextSource $context=null)
 Only public since 1.21.
 
 addHelpLink ( $to, $overrideBaseUrl=false)
 Adds help link with an icon via page indicators.
 
 getArticle ()
 Get a Article object.
 
 getAuthority ()
 Shortcut to get the Authority executing this instance.
 
 getContext ()
 Get the IContextSource in use here.
 
 getLanguage ()
 Shortcut to get the user Language being used for this instance.
 
 getOutput ()
 Get the OutputPage being used for this instance.
 
 getRequest ()
 Get the WebRequest being used for this instance.
 
 getSkin ()
 Shortcut to get the Skin being used for this instance.
 
 getTitle ()
 Shortcut to get the Title object from the page.
 
 getUser ()
 Shortcut to get the User being used for this instance.
 
 getWikiPage ()
 Get a WikiPage object.
 
 msg ( $key,... $params)
 Get a Message object with context set Parameters are the same as wfMessage()
 
 needsReadRights ()
 Indicates whether this action requires read rights.
 
 requiresUnblock ()
 Whether this action can still be executed by a blocked user.
 
 requiresWrite ()
 Whether this action requires the wiki not to be locked.
 

Protected Member Functions

 addStatePropagationFields (HTMLForm $form)
 
 alterForm (HTMLForm $form)
 Play with the HTMLForm if you need to more substantially.
 
 checkCanExecute (User $user)
 Checks if the given user (identified by an object) can perform this action.
 
 getFormFields ()
 Get an HTMLForm descriptor array.
 
 initFromParameters ()
 
 preText ()
 Add pre- or post-text to the form.
 
 usesOOUI ()
 Whether the form should use OOUI.
 
- Protected Member Functions inherited from FormAction
 getForm ()
 Get the HTMLForm to control behavior.
 
 postText ()
 
- Protected Member Functions inherited from Action
 getHookContainer ()
 
 getHookRunner ()
 
 getPageTitle ()
 Returns the name that goes in the <h1> page title.
 
 setHeaders ()
 Set output headers for noindexing etc.
 
 useTransactionalTimeLimit ()
 Call wfTransactionalTimeLimit() if this request was POSTed.
 

Protected Attributes

 $cur = 0
 
RevisionRecord null $curRev = null
 
 $undo = 0
 
 $undoafter = 0
 
- Protected Attributes inherited from Action
IContextSource null $context
 IContextSource if specified; otherwise we'll use the Context from the Page.
 
array $fields
 The fields used to create the HTMLForm.
 
WikiPage Article ImagePage CategoryPage Page $page
 Page on which we're performing the action.
 

Additional Inherited Members

- Static Public Member Functions inherited from Action
static exists (string $name)
 Check if a given action is recognised, even if it's disabled.
 
static factory (string $action, Article $article, IContextSource $context=null)
 Get an appropriate Action subclass for the given action.
 
static getActionName (IContextSource $context)
 Get the action that will be executed, not necessarily the one passed passed through the "action" request parameter.
 

Detailed Description

Temporary action for MCR undos.

This is intended to go away when real MCR support is added to EditPage and the standard undo-with-edit behavior can be implemented there instead.

If this were going to be kept, we'd probably want to figure out a good way to reuse the same code for generating the headers, summary box, and buttons on EditPage and here, and to better share the diffing and preview logic between the two. But doing that now would require much of the rewriting of EditPage that we're trying to put off by doing this instead.

Since
1.32

Definition at line 32 of file McrUndoAction.php.

Constructor & Destructor Documentation

◆ __construct()

McrUndoAction::__construct ( Page $page,
IContextSource $context,
ReadOnlyMode $readOnlyMode,
RevisionLookup $revisionLookup,
RevisionRenderer $revisionRenderer,
Config $config )
Parameters
Page$page
IContextSource$context
ReadOnlyMode$readOnlyMode
RevisionLookup$revisionLookup
RevisionRenderer$revisionRenderer
Config$config

Definition at line 59 of file McrUndoAction.php.

References Config\get().

Member Function Documentation

◆ addStatePropagationFields()

McrUndoAction::addStatePropagationFields ( HTMLForm $form)
protected

Reimplemented in McrRestoreAction.

Definition at line 510 of file McrUndoAction.php.

References HTMLForm\addHiddenField().

Referenced by alterForm().

◆ alterForm()

McrUndoAction::alterForm ( HTMLForm $form)
protected

◆ checkCanExecute()

McrUndoAction::checkCanExecute ( User $user)
protected

Checks if the given user (identified by an object) can perform this action.

Can be overridden by sub-classes with more complicated permissions schemes. Failures here must throw subclasses of ErrorPageError

Since
1.17
Stability: stable
to override
Parameters
User$user
Exceptions
UserBlockedError|ReadOnlyError|PermissionsError

Reimplemented from Action.

Definition at line 160 of file McrUndoAction.php.

References $title, getTitle(), and initFromParameters().

◆ getDescription()

McrUndoAction::getDescription ( )

Returns the description that goes below the <h1> element.

Since
1.17
Stability: stable
to override
Returns
string HTML

Reimplemented from Action.

Reimplemented in McrRestoreAction.

Definition at line 78 of file McrUndoAction.php.

◆ getFormFields()

McrUndoAction::getFormFields ( )
protected

Get an HTMLForm descriptor array.

Stability: stable
to override
Returns
array

Reimplemented from FormAction.

Definition at line 444 of file McrUndoAction.php.

References Linker\commentBlock(), and Action\getRequest().

◆ getName()

McrUndoAction::getName ( )

Return the name of the action this object responds to.

Since
1.17
Returns
string Lowercase name

Reimplemented from Action.

Reimplemented in McrRestoreAction.

Definition at line 74 of file McrUndoAction.php.

◆ getRestriction()

McrUndoAction::getRestriction ( )

Get the permission required to perform this action.

Often, but not always, the same as the action name

Since
1.17
Stability: stable
to override
Returns
string|null

Reimplemented from Action.

Definition at line 82 of file McrUndoAction.php.

◆ initFromParameters()

McrUndoAction::initFromParameters ( )
protected

Reimplemented in McrRestoreAction.

Definition at line 144 of file McrUndoAction.php.

References $curRev, Action\getRequest(), and Action\getWikiPage().

Referenced by checkCanExecute().

◆ onSubmit()

McrUndoAction::onSubmit ( $data)

Process the form on POST submission.

If you don't want to do anything with the form, just return false here.

This method will be passed to the HTMLForm as a submit callback (see HTMLForm::setSubmitCallback) and must return as documented for HTMLForm::trySubmit.

See also
HTMLForm::setSubmitCallback()
HTMLForm::trySubmit()
Parameters
array$data
Returns
bool|string|array|Status Must return as documented for HTMLForm::trySubmit

Reimplemented from FormAction.

Definition at line 356 of file McrUndoAction.php.

References $curRev, EDIT_AUTOSUMMARY, EDIT_UPDATE, getAuthority(), getContext(), MediaWiki\Revision\RevisionRecord\getId(), Action\getRequest(), MediaWiki\Revision\RevisionRecord\getSlotRoles(), getTitle(), getUser(), and Action\getWikiPage().

◆ onSuccess()

McrUndoAction::onSuccess ( )

Do something exciting on successful processing of the form.

This might be to show a confirmation message (watch, rollback, etc) or to redirect somewhere else (edit, protect, etc).

Reimplemented from FormAction.

Definition at line 516 of file McrUndoAction.php.

References Action\getOutput(), and getTitle().

◆ preText()

McrUndoAction::preText ( )
protected

Add pre- or post-text to the form.

Stability: stable
to override
Returns
string HTML which will be sent to $form->addPreText()

Reimplemented from FormAction.

Definition at line 520 of file McrUndoAction.php.

◆ show()

McrUndoAction::show ( )

The basic pattern for actions is to display some sort of HTMLForm UI, maybe with some stuff underneath (history etc); to do some processing on submission of that form (delete, protect, etc) and to do something exciting on 'success', be that display something new or redirect to somewhere.

Some actions have more exotic behavior, but that's what subclassing is for :D

Stability: stable
to override

Reimplemented from FormAction.

Definition at line 87 of file McrUndoAction.php.

References getContext(), Action\getOutput(), Action\getRequest(), SpecialPage\getTitleFor(), and Action\useTransactionalTimeLimit().

◆ usesOOUI()

McrUndoAction::usesOOUI ( )
protected

Whether the form should use OOUI.

Stability: stable
to override
Returns
bool

Reimplemented from FormAction.

Definition at line 440 of file McrUndoAction.php.

Member Data Documentation

◆ $cur

McrUndoAction::$cur = 0
protected

Definition at line 34 of file McrUndoAction.php.

◆ $curRev

RevisionRecord null McrUndoAction::$curRev = null
protected

◆ $undo

McrUndoAction::$undo = 0
protected

Definition at line 34 of file McrUndoAction.php.

◆ $undoafter

McrUndoAction::$undoafter = 0
protected

Definition at line 34 of file McrUndoAction.php.


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