1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-11-29 10:12:41 +01:00

Update accountadmin to use new admin empowerment code

Summary: Fixes https://discourse.phabricator-community.org/t/admin-account-creation-fails-call-to-undefined-method-phabricatorusereditor-makeadminuser/2227. This callsite got skipped when updating the EmpowerController to use the new transactional admin approval code.

Test Plan: Invoked `accountadmin` to promote a user, no longer got an exception.

Reviewers: epriestley

Reviewed By: epriestley

Subscribers: Korvin

Differential Revision: https://secure.phabricator.com/D19915
This commit is contained in:
Austin McKinley 2018-12-19 11:31:02 -08:00
parent aa3b2ec5dc
commit 979187132d
3 changed files with 44 additions and 3 deletions

View file

@ -200,9 +200,28 @@ $user->openTransaction();
$editor->updateUser($user, $verify_email); $editor->updateUser($user, $verify_email);
} }
$editor->makeAdminUser($user, $set_admin);
$editor->makeSystemAgentUser($user, $set_system_agent); $editor->makeSystemAgentUser($user, $set_system_agent);
$xactions = array();
$xactions[] = id(new PhabricatorUserTransaction())
->setTransactionType(
PhabricatorUserEmpowerTransaction::TRANSACTIONTYPE)
->setNewValue($set_admin);
$actor = PhabricatorUser::getOmnipotentUser();
$content_source = PhabricatorContentSource::newForSource(
PhabricatorConsoleContentSource::SOURCECONST);
$people_application_phid = id(new PhabricatorPeopleApplication())->getPHID();
$transaction_editor = id(new PhabricatorUserTransactionEditor())
->setActor($actor)
->setActingAsPHID($people_application_phid)
->setContentSource($content_source)
->setContinueOnMissingFields(true);
$transaction_editor->applyTransactions($user, $xactions);
$user->saveTransaction(); $user->saveTransaction();
echo pht('Saved changes.')."\n"; echo pht('Saved changes.')."\n";

View file

@ -416,7 +416,26 @@ final class PhabricatorAuthRegisterController
} }
if ($is_setup) { if ($is_setup) {
$editor->makeAdminUser($user, true); $xactions = array();
$xactions[] = id(new PhabricatorUserTransaction())
->setTransactionType(
PhabricatorUserEmpowerTransaction::TRANSACTIONTYPE)
->setNewValue(true);
$actor = PhabricatorUser::getOmnipotentUser();
$content_source = PhabricatorContentSource::newFromRequest(
$request);
$people_application_phid = id(new PhabricatorPeopleApplication())
->getPHID();
$transaction_editor = id(new PhabricatorUserTransactionEditor())
->setActor($actor)
->setActingAsPHID($people_application_phid)
->setContentSource($content_source)
->setContinueOnMissingFields(true);
$transaction_editor->applyTransactions($user, $xactions);
} }
$account->setUserPHID($user->getPHID()); $account->setUserPHID($user->getPHID());

View file

@ -45,7 +45,10 @@ final class PhabricatorUserEmpowerTransaction
'status as an administrator.'), $xaction); 'status as an administrator.'), $xaction);
} }
if (!$actor->getIsAdmin()) { $is_admin = $actor->getIsAdmin();
$is_omnipotent = $actor->isOmnipotent();
if (!$is_admin && !$is_omnipotent) {
$errors[] = $this->newInvalidError( $errors[] = $this->newInvalidError(
pht('You must be an administrator to create administrators.'), pht('You must be an administrator to create administrators.'),
$xaction); $xaction);