mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-12 07:41:04 +01:00
Integrate Pholio with Herald
Summary: Ref T2766. Does the integration via ApplicationTransactionsEditor. Only did addCC and Flag for proof of concept. Test Plan: Made a rule to cc, made a rule to flag. They worked! (will attach screens to diff) Reviewers: epriestley Reviewed By: epriestley CC: Korvin, aran Maniphest Tasks: T2766 Differential Revision: https://secure.phabricator.com/D6766
This commit is contained in:
parent
fde0d1f1d6
commit
f909a295f7
7 changed files with 211 additions and 0 deletions
|
@ -613,6 +613,7 @@ phutil_register_library_map(array(
|
||||||
'HeraldNewController' => 'applications/herald/controller/HeraldNewController.php',
|
'HeraldNewController' => 'applications/herald/controller/HeraldNewController.php',
|
||||||
'HeraldObjectTranscript' => 'applications/herald/storage/transcript/HeraldObjectTranscript.php',
|
'HeraldObjectTranscript' => 'applications/herald/storage/transcript/HeraldObjectTranscript.php',
|
||||||
'HeraldPHIDTypeRule' => 'applications/herald/phid/HeraldPHIDTypeRule.php',
|
'HeraldPHIDTypeRule' => 'applications/herald/phid/HeraldPHIDTypeRule.php',
|
||||||
|
'HeraldPholioMockAdapter' => 'applications/herald/adapter/HeraldPholioMockAdapter.php',
|
||||||
'HeraldRecursiveConditionsException' => 'applications/herald/engine/exception/HeraldRecursiveConditionsException.php',
|
'HeraldRecursiveConditionsException' => 'applications/herald/engine/exception/HeraldRecursiveConditionsException.php',
|
||||||
'HeraldRepetitionPolicyConfig' => 'applications/herald/config/HeraldRepetitionPolicyConfig.php',
|
'HeraldRepetitionPolicyConfig' => 'applications/herald/config/HeraldRepetitionPolicyConfig.php',
|
||||||
'HeraldRule' => 'applications/herald/storage/HeraldRule.php',
|
'HeraldRule' => 'applications/herald/storage/HeraldRule.php',
|
||||||
|
@ -2627,6 +2628,7 @@ phutil_register_library_map(array(
|
||||||
'HeraldInvalidFieldException' => 'Exception',
|
'HeraldInvalidFieldException' => 'Exception',
|
||||||
'HeraldNewController' => 'HeraldController',
|
'HeraldNewController' => 'HeraldController',
|
||||||
'HeraldPHIDTypeRule' => 'PhabricatorPHIDType',
|
'HeraldPHIDTypeRule' => 'PhabricatorPHIDType',
|
||||||
|
'HeraldPholioMockAdapter' => 'HeraldAdapter',
|
||||||
'HeraldRecursiveConditionsException' => 'Exception',
|
'HeraldRecursiveConditionsException' => 'Exception',
|
||||||
'HeraldRule' =>
|
'HeraldRule' =>
|
||||||
array(
|
array(
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group herald
|
||||||
|
*/
|
||||||
abstract class HeraldAdapter {
|
abstract class HeraldAdapter {
|
||||||
|
|
||||||
const FIELD_TITLE = 'title';
|
const FIELD_TITLE = 'title';
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group herald
|
||||||
|
*/
|
||||||
final class HeraldCommitAdapter extends HeraldAdapter {
|
final class HeraldCommitAdapter extends HeraldAdapter {
|
||||||
|
|
||||||
const FIELD_NEED_AUDIT_FOR_PACKAGE = 'need-audit-for-package';
|
const FIELD_NEED_AUDIT_FOR_PACKAGE = 'need-audit-for-package';
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group herald
|
||||||
|
*/
|
||||||
final class HeraldDifferentialRevisionAdapter extends HeraldAdapter {
|
final class HeraldDifferentialRevisionAdapter extends HeraldAdapter {
|
||||||
|
|
||||||
protected $revision;
|
protected $revision;
|
||||||
|
|
115
src/applications/herald/adapter/HeraldPholioMockAdapter.php
Normal file
115
src/applications/herald/adapter/HeraldPholioMockAdapter.php
Normal file
|
@ -0,0 +1,115 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group herald
|
||||||
|
*/
|
||||||
|
final class HeraldPholioMockAdapter extends HeraldAdapter {
|
||||||
|
|
||||||
|
private $mock;
|
||||||
|
private $ccPHIDs = array();
|
||||||
|
|
||||||
|
public function setMock(PholioMock $mock) {
|
||||||
|
$this->mock = $mock;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
public function getMock() {
|
||||||
|
return $this->mock;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function setCcPHIDs(array $cc_phids) {
|
||||||
|
$this->ccPHIDs = $cc_phids;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
public function getCcPHIDs() {
|
||||||
|
return $this->ccPHIDs;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAdapterContentName() {
|
||||||
|
return pht('Pholio Mocks');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getFields() {
|
||||||
|
return array(
|
||||||
|
self::FIELD_TITLE,
|
||||||
|
self::FIELD_BODY,
|
||||||
|
self::FIELD_AUTHOR,
|
||||||
|
self::FIELD_CC,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getActions($rule_type) {
|
||||||
|
switch ($rule_type) {
|
||||||
|
case HeraldRuleTypeConfig::RULE_TYPE_GLOBAL:
|
||||||
|
return array(
|
||||||
|
self::ACTION_ADD_CC,
|
||||||
|
self::ACTION_NOTHING,
|
||||||
|
);
|
||||||
|
case HeraldRuleTypeConfig::RULE_TYPE_PERSONAL:
|
||||||
|
return array(
|
||||||
|
self::ACTION_ADD_CC,
|
||||||
|
self::ACTION_FLAG,
|
||||||
|
self::ACTION_NOTHING,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getPHID() {
|
||||||
|
return $this->getMock()->getPHID();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getHeraldName() {
|
||||||
|
return 'M'.$this->getMock()->getID();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getHeraldField($field) {
|
||||||
|
switch ($field) {
|
||||||
|
case self::FIELD_TITLE:
|
||||||
|
return $this->getMock()->getName();
|
||||||
|
case self::FIELD_BODY:
|
||||||
|
return $this->getMock()->getDescription();
|
||||||
|
case self::FIELD_AUTHOR:
|
||||||
|
return $this->getMock()->getAuthorPHID();
|
||||||
|
case self::FIELD_CC:
|
||||||
|
return PhabricatorSubscribersQuery::loadSubscribersForPHID(
|
||||||
|
$this->getMock()->getPHID());
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::getHeraldField($field);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyHeraldEffects(array $effects) {
|
||||||
|
assert_instances_of($effects, 'HeraldEffect');
|
||||||
|
|
||||||
|
$result = array();
|
||||||
|
foreach ($effects as $effect) {
|
||||||
|
$action = $effect->getAction();
|
||||||
|
switch ($action) {
|
||||||
|
case self::ACTION_NOTHING:
|
||||||
|
$result[] = new HeraldApplyTranscript(
|
||||||
|
$effect,
|
||||||
|
true,
|
||||||
|
pht('Great success at doing nothing.'));
|
||||||
|
break;
|
||||||
|
case self::ACTION_ADD_CC:
|
||||||
|
$add_cc = array();
|
||||||
|
foreach ($effect->getTarget() as $phid) {
|
||||||
|
$add_cc[$phid] = true;
|
||||||
|
}
|
||||||
|
$this->setCcPHIDs(array_keys($add_cc));
|
||||||
|
$result[] = new HeraldApplyTranscript(
|
||||||
|
$effect,
|
||||||
|
true,
|
||||||
|
pht('Added address to cc list.'));
|
||||||
|
break;
|
||||||
|
case self::ACTION_FLAG:
|
||||||
|
$result[] = parent::applyFlagEffect(
|
||||||
|
$effect,
|
||||||
|
$this->getMock()->getPHID());
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
throw new Exception("No rules to handle action '{$action}'.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
}
|
|
@ -383,6 +383,33 @@ final class PholioMockEditor extends PhabricatorApplicationTransactionEditor {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function supportsHerald() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function buildHeraldAdapter(
|
||||||
|
PhabricatorLiskDAO $object,
|
||||||
|
array $xactions) {
|
||||||
|
|
||||||
|
return id(new HeraldPholioMockAdapter())
|
||||||
|
->setMock($object);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function didApplyHeraldRules(
|
||||||
|
PhabricatorLiskDAO $object,
|
||||||
|
HeraldAdapter $adapter,
|
||||||
|
HeraldTranscript $transcript) {
|
||||||
|
|
||||||
|
$cc_phids = $adapter->getCcPHIDs();
|
||||||
|
if ($cc_phids) {
|
||||||
|
id(new PhabricatorSubscriptionsEditor())
|
||||||
|
->setObject($object)
|
||||||
|
->setActor($this->requireActor())
|
||||||
|
->subscribeImplicit($cc_phids)
|
||||||
|
->save();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
protected function sortTransactions(array $xactions) {
|
protected function sortTransactions(array $xactions) {
|
||||||
$head = array();
|
$head = array();
|
||||||
$tail = array();
|
$tail = array();
|
||||||
|
|
|
@ -16,6 +16,8 @@ abstract class PhabricatorApplicationTransactionEditor
|
||||||
private $mentionedPHIDs;
|
private $mentionedPHIDs;
|
||||||
private $continueOnNoEffect;
|
private $continueOnNoEffect;
|
||||||
private $parentMessageID;
|
private $parentMessageID;
|
||||||
|
private $heraldAdapter;
|
||||||
|
private $heraldTranscript;
|
||||||
private $subscribers;
|
private $subscribers;
|
||||||
|
|
||||||
private $isPreview;
|
private $isPreview;
|
||||||
|
@ -439,6 +441,10 @@ abstract class PhabricatorApplicationTransactionEditor
|
||||||
$this->applyExternalEffects($object, $xaction);
|
$this->applyExternalEffects($object, $xaction);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->supportsHerald()) {
|
||||||
|
$this->applyHeraldRules($object, $xactions);
|
||||||
|
}
|
||||||
|
|
||||||
$this->applyFinalEffects($object, $xactions);
|
$this->applyFinalEffects($object, $xactions);
|
||||||
|
|
||||||
if ($read_locking) {
|
if ($read_locking) {
|
||||||
|
@ -1324,6 +1330,58 @@ abstract class PhabricatorApplicationTransactionEditor
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* -( Herald Integration )-------------------------------------------------- */
|
||||||
|
|
||||||
|
|
||||||
|
protected function supportsHerald() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function buildHeraldAdapter(
|
||||||
|
PhabricatorLiskDAO $object,
|
||||||
|
array $xactions) {
|
||||||
|
throw new Exception('No herald adapter specified.');
|
||||||
|
}
|
||||||
|
|
||||||
|
private function setHeraldAdapter(HeraldAdapter $adapter) {
|
||||||
|
$this->heraldAdapter = $adapter;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getHeraldAdapter() {
|
||||||
|
return $this->heraldAdapter;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function setHeraldTranscript(HeraldTranscript $transcript) {
|
||||||
|
$this->heraldTranscript = $transcript;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getHeraldTranscript() {
|
||||||
|
return $this->heraldTranscript;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function applyHeraldRules(
|
||||||
|
PhabricatorLiskDAO $object,
|
||||||
|
array $xactions) {
|
||||||
|
|
||||||
|
$adapter = $this->buildHeraldAdapter($object, $xactions);
|
||||||
|
$xscript = HeraldEngine::loadAndApplyRules($adapter);
|
||||||
|
|
||||||
|
$this->setHeraldAdapter($adapter);
|
||||||
|
$this->setHeraldTranscript($xscript);
|
||||||
|
|
||||||
|
$this->didApplyHeraldRules($object, $adapter, $xscript);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function didApplyHeraldRules(
|
||||||
|
PhabricatorLiskDAO $object,
|
||||||
|
HeraldAdapter $adapter,
|
||||||
|
HeraldTranscript $transcript) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* -( Custom Fields )------------------------------------------------------ */
|
/* -( Custom Fields )------------------------------------------------------ */
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue