mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/AbuseFilter.git
synced 2024-11-27 15:30:42 +00:00
5d4025d8c9
This commit doesn't change any permissions for anybody. It's the first step to achieve what the task asks for. Bug: T242821 Change-Id: I8060ca926e6769b11d470fe4037854cda496000d
105 lines
3 KiB
PHP
105 lines
3 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\AbuseFilter\View;
|
|
|
|
use HTMLForm;
|
|
use IContextSource;
|
|
use MediaWiki\Extension\AbuseFilter\AbuseFilterPermissionManager;
|
|
use MediaWiki\Extension\AbuseFilter\EditBox\EditBoxBuilderFactory;
|
|
use MediaWiki\Extension\AbuseFilter\EditBox\EditBoxField;
|
|
use MediaWiki\Linker\LinkRenderer;
|
|
use Xml;
|
|
|
|
class AbuseFilterViewTools extends AbuseFilterView {
|
|
|
|
/**
|
|
* @var EditBoxBuilderFactory
|
|
*/
|
|
private $boxBuilderFactory;
|
|
|
|
/**
|
|
* @param AbuseFilterPermissionManager $afPermManager
|
|
* @param EditBoxBuilderFactory $boxBuilderFactory
|
|
* @param IContextSource $context
|
|
* @param LinkRenderer $linkRenderer
|
|
* @param string $basePageName
|
|
* @param array $params
|
|
*/
|
|
public function __construct(
|
|
AbuseFilterPermissionManager $afPermManager,
|
|
EditBoxBuilderFactory $boxBuilderFactory,
|
|
IContextSource $context,
|
|
LinkRenderer $linkRenderer,
|
|
string $basePageName,
|
|
array $params
|
|
) {
|
|
parent::__construct( $afPermManager, $context, $linkRenderer, $basePageName, $params );
|
|
$this->boxBuilderFactory = $boxBuilderFactory;
|
|
}
|
|
|
|
/**
|
|
* Shows the page
|
|
*/
|
|
public function show() {
|
|
$out = $this->getOutput();
|
|
$out->enableOOUI();
|
|
$out->addHelpLink( 'Extension:AbuseFilter/Rules format' );
|
|
$request = $this->getRequest();
|
|
|
|
if ( !$this->afPermManager->canUseTestTools( $this->getUser() ) ) {
|
|
// TODO: the message still refers to the old rights
|
|
$out->addWikiMsg( 'abusefilter-mustviewprivateoredit' );
|
|
return;
|
|
}
|
|
|
|
// Header
|
|
$out->addWikiMsg( 'abusefilter-tools-text' );
|
|
|
|
$boxBuilder = $this->boxBuilderFactory->newEditBoxBuilder( $this, $this->getUser(), $out );
|
|
|
|
// Expression evaluator
|
|
$formDesc = [
|
|
'rules' => [
|
|
'class' => EditBoxField::class,
|
|
'html' => $boxBuilder->buildEditBox(
|
|
$request->getText( 'wpFilterRules' ),
|
|
true,
|
|
false,
|
|
false
|
|
)
|
|
]
|
|
];
|
|
|
|
HTMLForm::factory( 'ooui', $formDesc, $this->getContext() )
|
|
->setMethod( 'GET' )
|
|
->setWrapperLegendMsg( 'abusefilter-tools-expr' )
|
|
->setSubmitTextMsg( 'abusefilter-tools-submitexpr' )
|
|
->setSubmitId( 'mw-abusefilter-submitexpr' )
|
|
->setFooterText( Xml::element( 'pre', [ 'id' => 'mw-abusefilter-expr-result' ], ' ' ) )
|
|
->prepareForm()
|
|
->displayForm( false );
|
|
|
|
$out->addModules( 'ext.abuseFilter.tools' );
|
|
|
|
if ( $this->afPermManager->canEdit( $this->getUser() ) ) {
|
|
// Hacky little box to re-enable autoconfirmed if it got disabled
|
|
$formDescriptor = [
|
|
'RestoreAutoconfirmed' => [
|
|
'label-message' => 'abusefilter-tools-reautoconfirm-user',
|
|
'type' => 'user',
|
|
'name' => 'wpReAutoconfirmUser',
|
|
'id' => 'reautoconfirm-user',
|
|
'infusable' => true
|
|
],
|
|
];
|
|
$htmlForm = HTMLForm::factory( 'ooui', $formDescriptor, $this->getContext() );
|
|
$htmlForm->setWrapperLegendMsg( 'abusefilter-tools-reautoconfirm' )
|
|
->setSubmitTextMsg( 'abusefilter-tools-reautoconfirm-submit' )
|
|
->setSubmitName( 'wpReautoconfirmSubmit' )
|
|
->setSubmitId( 'mw-abusefilter-reautoconfirmsubmit' )
|
|
->prepareForm()
|
|
->displayForm( false );
|
|
}
|
|
}
|
|
}
|