mediawiki-extensions-OATHAuth/special/ProxySpecialPage.php
Tyler Anthony Romeo 0c389f5025 Refactored special pages into HTMLForm and proxy
Made new class ProxySpecialPage, which acts as a
proxy object to another SpecialPage object that is
determined based on context information other than
the title.

Then Special:OATH has been split into two separate
special page classes (both FormSpecialPages using
HTMLForm) that are routed to by a ProxySpecialPage
object.

In addition, the form for enabling two-factor auth
has been refactored into vform style, with some
better instructions on how to enable two-factor
authentication.

Change-Id: Ib9117cbc9d7f044de9607db81a157e1b472b5ec0
2016-03-23 11:26:04 -07:00

213 lines
3.7 KiB
PHP

<?php
/**
* A proxy class that routes a special page to other special pages based on
* request parameters
*/
abstract class ProxySpecialPage extends SpecialPage {
/**
* @var SpecialPage|null Target page to execute
*/
private $target = null;
/**
* Instantiate a SpecialPage based on request parameters
*
* The page returned by this function will be cached and used as
* the target page for this proxy object.
*
* @return SpecialPage
*/
abstract protected function getTargetPage();
/**
* Helper function that initializes the target SpecialPage object
*/
private function init() {
if ( $this->target === null ) {
$this->target = $this->getTargetPage();
}
}
/**
* Magic function that proxies function calls to the target object
*
* @param string $method Method name being called
* @param array $args Array of arguments
*
* @return mixed
*/
public function __call( $method, $args ) {
$this->init();
return call_user_func_array( array( $this->target, $method ), $args );
}
/**
* @return string
*/
function getName() {
$this->init();
return $this->target->getName();
}
/**
* @param string|bool $subpage
* @return Title
*/
function getPageTitle( $subpage = false ) {
$this->init();
return $this->target->getPageTitle( $subpage );
}
/**
* @return string
*/
function getLocalName() {
$this->init();
return $this->target->getLocalName();
}
/**
* @return string
*/
function getRestriction() {
$this->init();
return $this->target->getRestriction();
}
/**
* @return bool
*/
function isListed() {
$this->init();
return $this->target->isListed();
}
/**
* @param bool $listed
* @return bool
*/
function setListed( $listed ) {
$this->init();
return $this->target->setListed( $listed );
}
/**
* @param bool $x
* @return bool
*/
function listed( $x = null ) {
$this->init();
return $this->target->listed( $x );
}
/**
* @return bool
*/
public function isIncludable() {
$this->init();
return $this->target->isIncludable();
}
/**
* @param bool $x
* @return bool
*/
function including( $x = null ) {
$this->init();
return $this->target->including( $x );
}
/**
* @return bool
*/
public function isRestricted() {
$this->init();
return $this->target->isRestricted();
}
/**
* @param User $user
* @return bool
*/
public function userCanExecute( User $user ) {
$this->init();
return $this->target->userCanExecute( $user );
}
/**
* @throws PermissionsError
*/
function displayRestrictionError() {
$this->init();
$this->target->displayRestrictionError();
}
/**
* @return void
* @throws PermissionsError
*/
public function checkPermissions() {
$this->init();
$this->target->checkPermissions();
}
/**
* @param string|null $subPage
*/
protected function beforeExecute( $subPage ) {
$this->init();
$this->target->beforeExecute( $subPage );
}
/**
* @param string|null $subPage
*/
protected function afterExecute( $subPage ) {
$this->init();
$this->target->afterExecute( $subPage );
}
/**
* @param string|null $subPage
*/
public function execute( $subPage ) {
$this->init();
$this->target->execute( $subPage );
}
/**
* @return string
*/
function getDescription() {
$this->init();
return $this->target->getDescription();
}
/**
* @param IContextSource $context
*/
public function setContext( $context ) {
$this->init();
$this->target->setContext( $context );
parent::setContext( $context );
}
/**
* @return string
*/
protected function getRobotPolicy() {
$this->init();
return $this->target->getRobotPolicy();
}
/**
* @return string
*/
protected function getGroupName() {
$this->init();
return $this->target->getGroupName();
}
}