Skip to content

Commit

Permalink
Inject CentralAuth services again
Browse files Browse the repository at this point in the history
  • Loading branch information
Universal-Omega authored Mar 3, 2024
1 parent b6ce2ff commit 15bd37d
Showing 1 changed file with 39 additions and 30 deletions.
69 changes: 39 additions & 30 deletions includes/SpecialRemovePII.php
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,14 @@
use FormSpecialPage;
use Html;
use ManualLogEntry;
use MediaWiki\Extension\CentralAuth\CentralAuthDatabaseManager;
use MediaWiki\Extension\CentralAuth\GlobalRename\GlobalRenameUser;
use MediaWiki\Extension\CentralAuth\GlobalRename\GlobalRenameUserDatabaseUpdates;
use MediaWiki\Extension\CentralAuth\GlobalRename\GlobalRenameUserStatus;
use MediaWiki\Extension\CentralAuth\GlobalRename\GlobalRenameUserValidator;
use MediaWiki\Extension\CentralAuth\User\CentralAuthAntiSpoofManager;
use MediaWiki\Extension\CentralAuth\User\CentralAuthUser;
use MediaWiki\Extension\CentralAuth\Widget\HTMLGlobalUserTextField;
use MediaWiki\Http\HttpRequestFactory;
use MediaWiki\JobQueue\JobQueueGroupFactory;
use MediaWiki\MediaWikiServices;
Expand All @@ -18,9 +26,19 @@
use WikiMap;

class SpecialRemovePII extends FormSpecialPage {

/** @var CentralAuthAntiSpoofManager|null */
private $centralAuthAntiSpoofManager;

/** @var CentralAuthDatabaseManager|null */
private $centralAuthDatabaseManager;

/** @var Config */
private $config;

/** @var GlobalRenameUserValidator|null */
private $globalRenameUserValidator;

/** @var HttpRequestFactory */
private $httpRequestFactory;

Expand All @@ -35,15 +53,23 @@ class SpecialRemovePII extends FormSpecialPage {
* @param HttpRequestFactory $httpRequestFactory
* @param JobQueueGroupFactory $jobQueueGroupFactory
* @param UserFactory $userFactory
* @param ?CentralAuthAntiSpoofManager $centralAuthAntiSpoofManager
* @param ?CentralAuthDatabaseManager $centralAuthDatabaseManager
* @param ?GlobalRenameUserValidator $globalRenameUserValidator
*/
public function __construct(
ConfigFactory $configFactory,
HttpRequestFactory $httpRequestFactory,
JobQueueGroupFactory $jobQueueGroupFactory,
UserFactory $userFactory
UserFactory $userFactory,
?CentralAuthAntiSpoofManager $centralAuthAntiSpoofManager,
?CentralAuthDatabaseManager $centralAuthDatabaseManager,
?GlobalRenameUserValidator $globalRenameUserValidator
) {
parent::__construct( 'RemovePII', 'handle-pii' );

$this->centralAuthAntiSpoofManager = $centralAuthAntiSpoofManager;
$this->centralAuthDatabaseManager = $centralAuthDatabaseManager;
$this->config = $configFactory->makeConfig( 'RemovePII' );
$this->httpRequestFactory = $httpRequestFactory;
$this->jobQueueGroupFactory = $jobQueueGroupFactory;
Expand Down Expand Up @@ -87,7 +113,7 @@ protected function getFormFields() {
];

$formDescriptor['oldname'] = [
'class' => \MediaWiki\Extension\CentralAuth\Widget\HTMLGlobalUserTextField::class,
'class' => HTMLGlobalUserTextField::class,
'required' => true,
'label-message' => 'removepii-oldname-label',
];
Expand Down Expand Up @@ -154,22 +180,16 @@ public function isMatchingAssociatedDPARequest( ?string $value, array $alldata )
* @return Status
*/
public function validateCentralAuth( array $formData ) {
if ( !ExtensionRegistry::getInstance()->isLoaded( 'CentralAuth' ) ) {
if ( !ExtensionRegistry::getInstance()->isLoaded( 'CentralAuth' ) || !$this->globalRenameUserValidator ) {
return Status::newFatal( 'removepii-centralauth-notinstalled' );
}

if ( version_compare( MW_VERSION, '1.40', '<' ) &&
!ExtensionRegistry::getInstance()->isLoaded( 'Renameuser' )
) {
return Status::newFatal( 'centralauth-rename-notinstalled' );
}

$oldUser = $this->userFactory->newFromName( $formData['oldname'] );
if ( !$oldUser ) {
return Status::newFatal( 'centralauth-rename-doesnotexist' );
}

$oldCentral = \MediaWiki\Extension\CentralAuth\User\CentralAuthUser::getInstanceByName( $formData['oldname'] );
$oldCentral = CentralAuthUser::getInstanceByName( $formData['oldname'] );
$canSuppress = $this->getUser() && $this->getUser()->isAllowed( 'centralauth-suppress' );

if ( ( $oldCentral->isSuppressed() || $oldCentral->isHidden() ) &&
Expand All @@ -187,10 +207,7 @@ public function validateCentralAuth( array $formData ) {
return Status::newFatal( 'centralauth-rename-badusername' );
}

$globalRenameUserValidator = MediaWikiServices::getInstance()->getService(
'CentralAuth.GlobalRenameUserValidator'
);
return $globalRenameUserValidator->validate( $oldUser, $newUser );
return $this->globalRenameUserValidator->validate( $oldUser, $newUser );
}

/**
Expand Down Expand Up @@ -218,25 +235,17 @@ public function onSubmit( array $formData ) {
return Status::newFatal( 'unknown-error' );
}

$caDbManager = MediaWikiServices::getInstance()->getService(
'CentralAuth.CentralAuthDatabaseManager'
);

$caAntiSpoofManager = MediaWikiServices::getInstance()->getService(
'CentralAuth.CentralAuthAntiSpoofManager'
);

$globalRenameUser = new \MediaWiki\Extension\CentralAuth\GlobalRename\GlobalRenameUser(
$globalRenameUser = new GlobalRenameUser(
$this->getUser(),
$oldUser,
\MediaWiki\Extension\CentralAuth\User\CentralAuthUser::getInstance( $oldUser ),
CentralAuthUser::getInstance( $oldUser ),
$newUser,
\MediaWiki\Extension\CentralAuth\User\CentralAuthUser::getInstance( $newUser ),
new \MediaWiki\Extension\CentralAuth\GlobalRename\GlobalRenameUserStatus( $newUser->getName() ),
CentralAuthUser::getInstance( $newUser ),
new GlobalRenameUserStatus( $newUser->getName() ),
$this->jobQueueGroupFactory,
new \MediaWiki\Extension\CentralAuth\GlobalRename\GlobalRenameUserDatabaseUpdates( $caDbManager ),
new GlobalRenameUserDatabaseUpdates( $this->centralAuthDatabaseManager ),
new RemovePIIGlobalRenameUserLogger( $this->getUser() ),
$caAntiSpoofManager
$this->centralAuthAntiSpoofManager
);

$globalRenameUser->rename(
Expand All @@ -262,9 +271,9 @@ public function onSubmit( array $formData ) {
'newname' => $newName,
];

$oldCentral = \MediaWiki\Extension\CentralAuth\User\CentralAuthUser::getInstanceByName( $oldName );
$oldCentral = CentralAuthUser::getInstanceByName( $oldName );

$newCentral = \MediaWiki\Extension\CentralAuth\User\CentralAuthUser::getInstanceByName( $newName );
$newCentral = CentralAuthUser::getInstanceByName( $newName );

if ( $oldCentral->renameInProgress() ) {
$out->addHTML(
Expand Down

0 comments on commit 15bd37d

Please sign in to comment.