mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 15:21:03 +01:00
Pass a real viewer to HeraldAdapter when doing test console runs
Summary: Depends on D18932. Ref T13048. See PHI276. In the cluster, we don't have device keys on `web` nodes. This is generally good, since they don't need them, and it means that we aren't putting more credentials than we need on those hosts. However, it means that when we pull diff content to test "Commit" rules via the Herald test console, we use the omnipotent user and try to use device credentials, and this fails since we don't have any. Instead, pass the real viewer in this case so we just sign the request as them, like we do for normal Diffusion requests. Test Plan: Wrote and ran a commit content rule locally, no issues. This isn't completely convincing since my local setup does have device credentials, but I'll double-check in production once this deploys. Reviewers: amckinley Reviewed By: amckinley Maniphest Tasks: T13048 Differential Revision: https://secure.phabricator.com/D18933
This commit is contained in:
parent
a9f87857af
commit
5058cfb972
3 changed files with 24 additions and 2 deletions
|
@ -209,7 +209,7 @@ final class HeraldCommitAdapter
|
||||||
}
|
}
|
||||||
|
|
||||||
private function loadCommitDiff() {
|
private function loadCommitDiff() {
|
||||||
$viewer = PhabricatorUser::getOmnipotentUser();
|
$viewer = $this->getViewer();
|
||||||
|
|
||||||
$byte_limit = self::getEnormousByteLimit();
|
$byte_limit = self::getEnormousByteLimit();
|
||||||
$time_limit = self::getEnormousTimeLimit();
|
$time_limit = self::getEnormousTimeLimit();
|
||||||
|
|
|
@ -38,6 +38,7 @@ abstract class HeraldAdapter extends Phobject {
|
||||||
private $actionMap;
|
private $actionMap;
|
||||||
private $edgeCache = array();
|
private $edgeCache = array();
|
||||||
private $forbiddenActions = array();
|
private $forbiddenActions = array();
|
||||||
|
private $viewer;
|
||||||
|
|
||||||
public function getEmailPHIDs() {
|
public function getEmailPHIDs() {
|
||||||
return array_values($this->emailPHIDs);
|
return array_values($this->emailPHIDs);
|
||||||
|
@ -55,10 +56,29 @@ abstract class HeraldAdapter extends Phobject {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setViewer(PhabricatorUser $viewer) {
|
||||||
|
$this->viewer = $viewer;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getViewer() {
|
||||||
|
// See PHI276. Normally, Herald runs without regard for policy checks.
|
||||||
|
// However, we use a real viewer during test console runs: this makes
|
||||||
|
// intracluster calls to Diffusion APIs work even if web nodes don't
|
||||||
|
// have privileged credentials.
|
||||||
|
|
||||||
|
if ($this->viewer) {
|
||||||
|
return $this->viewer;
|
||||||
|
}
|
||||||
|
|
||||||
|
return PhabricatorUser::getOmnipotentUser();
|
||||||
|
}
|
||||||
|
|
||||||
public function setContentSource(PhabricatorContentSource $content_source) {
|
public function setContentSource(PhabricatorContentSource $content_source) {
|
||||||
$this->contentSource = $content_source;
|
$this->contentSource = $content_source;
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getContentSource() {
|
public function getContentSource() {
|
||||||
return $this->contentSource;
|
return $this->contentSource;
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,7 +39,9 @@ final class HeraldTestConsoleController extends HeraldController {
|
||||||
$object = $this->getTestObject();
|
$object = $this->getTestObject();
|
||||||
$adapter = $this->getTestAdapter();
|
$adapter = $this->getTestAdapter();
|
||||||
|
|
||||||
$adapter->setIsNewObject(false);
|
$adapter
|
||||||
|
->setIsNewObject(false)
|
||||||
|
->setViewer($viewer);
|
||||||
|
|
||||||
$rules = id(new HeraldRuleQuery())
|
$rules = id(new HeraldRuleQuery())
|
||||||
->setViewer($viewer)
|
->setViewer($viewer)
|
||||||
|
|
Loading…
Reference in a new issue