wiki.techinc.nl/includes/block/SystemBlock.php
Thalia 824655f3b7 Separate Block into AbstractBlock, Block and SystemBlock
This commit splits the existing Block class into AbstractBlock, Block
and SystemBlock.

Before this patch, the Block class represents several types of
blocks, which can be separated into blocks stored in the database,
and temporary blocks created by the system. These are now
represented by Block and SystemBlock, which inherit from
AbstractBlock.

This lays the foundations for:
* enforcing block parameters from multiple blocks that apply to a
user/IP address
* improvements to the Block API, including the addition of services

Breaking changes: functions expecting a Block object should still
expect a Block object if it came from the database, but other
functions may now need to expect an AbstractBlock or SystemBlock
object. (Note that an alternative naming scheme, in which the
abstract class is called Block and the subclasses are DatabaseBlock
and SystemBlock, avoids this breakage. However, it introduces more
breakages to calls to static Block methods and new Block
instantiations.)

Changes to tests: system blocks don't set the $blockCreateAccount or
$mExipry block properties, so remove/change any tests that assume
they do.

Bug: T222737
Change-Id: I83bceb5e5049e254c90ace060f8f8fad44696c67
2019-05-07 17:36:31 -05:00

107 lines
3 KiB
PHP

<?php
/**
* Class for temporary blocks created on enforcement.
*
* 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;
/**
* System blocks are temporary blocks that are created on enforcement (e.g.
* from IP blacklists) and are not saved to the database. The target of a
* system block is an IP address. System blocks do not give rise to
* autoblocks and are not tracked with cookies.
*
* @since 1.34
*/
class SystemBlock extends AbstractBlock {
/** @var string|null */
private $systemBlockType;
/**
* Create a new block with specified parameters on a user, IP or IP range.
*
* @param array $options Parameters of the block:
* systemBlock string Indicate that this block is automatically
* created by MediaWiki rather than being stored
* in the database. Value is a string to return
* from self::getSystemBlockType().
*/
function __construct( $options = [] ) {
parent::__construct( $options );
$defaults = [
'systemBlock' => null,
];
$options += $defaults;
$this->systemBlockType = $options['systemBlock'];
}
/**
* Get the system block type, if any. A SystemBlock can have the following types:
* - 'proxy': the IP is blacklisted in $wgProxyList
* - 'dnsbl': the IP is associated with a blacklisted domain in $wgDnsBlacklistUrls
* - 'wgSoftBlockRanges': the IP is covered by $wgSoftBlockRanges
* - 'global-block': for backwards compatability with the UserIsBlockedGlobally hook
*
* @since 1.29
* @return string|null
*/
public function getSystemBlockType() {
return $this->systemBlockType;
}
/**
* @inheritDoc
*/
public function getPermissionsError( IContextSource $context ) {
$params = $this->getBlockErrorParams( $context );
// TODO: Clean up error messages params so we don't have to do this
$params[ 4 ] = $this->getSystemBlockType();
$msg = 'systemblockedtext';
array_unshift( $params, $msg );
return $params;
}
/**
* @inheritDoc
*/
public function appliesToPasswordReset() {
switch ( $this->getSystemBlockType() ) {
case null:
case 'global-block':
return $this->isCreateAccountBlocked();
case 'proxy':
return true;
case 'dnsbl':
case 'wgSoftBlockRanges':
return false;
default:
return true;
}
}
}