Give a custom reason and include the user's IP address and the expiry of the longest block. Bug: T225748 Change-Id: Ie147cca625365c1a01e2ed18819e5d6e3946865e
178 lines
4.4 KiB
PHP
178 lines
4.4 KiB
PHP
<?php
|
|
/**
|
|
* Class for blocks composed from multiple blocks.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
*
|
|
* @file
|
|
*/
|
|
|
|
namespace MediaWiki\Block;
|
|
|
|
use IContextSource;
|
|
use Title;
|
|
|
|
/**
|
|
* Multiple Block class.
|
|
*
|
|
* Multiple blocks exist to enforce restrictions from more than one block, if several
|
|
* blocks apply to a user/IP. Multiple blocks are created temporarily on enforcement.
|
|
*
|
|
* @since 1.34
|
|
*/
|
|
class CompositeBlock extends AbstractBlock {
|
|
/** @var AbstractBlock[] */
|
|
private $originalBlocks;
|
|
|
|
/**
|
|
* Create a new block with specified parameters on a user, IP or IP range.
|
|
*
|
|
* @param array $options Parameters of the block:
|
|
* originalBlocks Block[] Blocks that this block is composed from
|
|
*/
|
|
function __construct( $options = [] ) {
|
|
parent::__construct( $options );
|
|
|
|
$defaults = [
|
|
'originalBlocks' => [],
|
|
];
|
|
|
|
$options += $defaults;
|
|
|
|
$this->originalBlocks = $options[ 'originalBlocks' ];
|
|
|
|
$this->setHideName( $this->propHasValue( 'mHideName', true ) );
|
|
$this->isSitewide( $this->propHasValue( 'isSitewide', true ) );
|
|
$this->isEmailBlocked( $this->propHasValue( 'mBlockEmail', true ) );
|
|
$this->isCreateAccountBlocked( $this->propHasValue( 'blockCreateAccount', true ) );
|
|
$this->isUsertalkEditAllowed( !$this->propHasValue( 'allowUsertalk', false ) );
|
|
}
|
|
|
|
/**
|
|
* Determine whether any original blocks have a particular property set to a
|
|
* particular value.
|
|
*
|
|
* @param string $prop
|
|
* @param mixed $value
|
|
* @return bool At least one block has the property set to the value
|
|
*/
|
|
private function propHasValue( $prop, $value ) {
|
|
foreach ( $this->originalBlocks as $block ) {
|
|
if ( $block->$prop == $value ) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Determine whether any original blocks have a particular method returning a
|
|
* particular value.
|
|
*
|
|
* @param string $method
|
|
* @param mixed $value
|
|
* @param mixed ...$params
|
|
* @return bool At least one block has the method returning the value
|
|
*/
|
|
private function methodReturnsValue( $method, $value, ...$params ) {
|
|
foreach ( $this->originalBlocks as $block ) {
|
|
if ( $block->$method( ...$params ) == $value ) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* Get the original blocks from which this block is composed
|
|
*
|
|
* @since 1.34
|
|
* @return AbstractBlock[]
|
|
*/
|
|
public function getOriginalBlocks() {
|
|
return $this->originalBlocks;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function getExpiry() {
|
|
$maxExpiry = null;
|
|
foreach ( $this->originalBlocks as $block ) {
|
|
$expiry = $block->getExpiry();
|
|
if ( $maxExpiry === null || $expiry === '' || $expiry > $maxExpiry ) {
|
|
$maxExpiry = $expiry;
|
|
}
|
|
}
|
|
return $maxExpiry;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function getPermissionsError( IContextSource $context ) {
|
|
$params = $this->getBlockErrorParams( $context );
|
|
|
|
$msg = 'blockedtext-composite';
|
|
|
|
array_unshift( $params, $msg );
|
|
|
|
return $params;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function appliesToRight( $right ) {
|
|
return $this->methodReturnsValue( __FUNCTION__, true, $right );
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function appliesToUsertalk( Title $usertalk = null ) {
|
|
return $this->methodReturnsValue( __FUNCTION__, true, $usertalk );
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function appliesToTitle( Title $title ) {
|
|
return $this->methodReturnsValue( __FUNCTION__, true, $title );
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function appliesToNamespace( $ns ) {
|
|
return $this->methodReturnsValue( __FUNCTION__, true, $ns );
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function appliesToPage( $pageId ) {
|
|
return $this->methodReturnsValue( __FUNCTION__, true, $pageId );
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function appliesToPasswordReset() {
|
|
return $this->methodReturnsValue( __FUNCTION__, true );
|
|
}
|
|
|
|
}
|