2011-03-24 21:32:26 -07:00
|
|
|
<?php
|
|
|
|
|
2013-08-02 08:38:17 -07:00
|
|
|
final class HeraldDifferentialRevisionAdapter extends HeraldAdapter {
|
2011-03-24 21:32:26 -07:00
|
|
|
|
|
|
|
protected $revision;
|
2011-04-05 20:49:31 -07:00
|
|
|
protected $diff;
|
2011-03-24 21:32:26 -07:00
|
|
|
|
|
|
|
protected $explicitCCs;
|
|
|
|
protected $explicitReviewers;
|
|
|
|
protected $forbiddenCCs;
|
|
|
|
|
|
|
|
protected $newCCs = array();
|
|
|
|
protected $remCCs = array();
|
2011-05-27 15:52:26 -07:00
|
|
|
protected $emailPHIDs = array();
|
2013-10-05 10:36:26 -07:00
|
|
|
protected $addReviewerPHIDs = array();
|
2013-10-07 03:41:00 -07:00
|
|
|
protected $blockingReviewerPHIDs = array();
|
2013-11-08 16:48:17 -08:00
|
|
|
protected $buildPlans = array();
|
2011-03-24 21:32:26 -07:00
|
|
|
|
2011-04-05 20:49:31 -07:00
|
|
|
protected $repository;
|
|
|
|
protected $affectedPackages;
|
|
|
|
protected $changesets;
|
2014-04-14 12:06:26 -07:00
|
|
|
private $haveHunks;
|
2011-04-05 20:49:31 -07:00
|
|
|
|
2013-10-04 15:15:48 -07:00
|
|
|
public function getAdapterApplicationClass() {
|
|
|
|
return 'PhabricatorApplicationDifferential';
|
2013-08-02 08:55:13 -07:00
|
|
|
}
|
|
|
|
|
2013-10-05 12:55:34 -07:00
|
|
|
public function getObject() {
|
|
|
|
return $this->revision;
|
|
|
|
}
|
|
|
|
|
2014-03-05 12:07:13 -08:00
|
|
|
public function getDiff() {
|
|
|
|
return $this->diff;
|
|
|
|
}
|
|
|
|
|
2013-08-02 08:55:13 -07:00
|
|
|
public function getAdapterContentType() {
|
|
|
|
return 'differential';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getAdapterContentName() {
|
|
|
|
return pht('Differential Revisions');
|
|
|
|
}
|
|
|
|
|
2013-12-27 13:16:33 -08:00
|
|
|
public function getAdapterContentDescription() {
|
|
|
|
return pht(
|
|
|
|
"React to revisions being created or updated.\n".
|
|
|
|
"Revision rules can send email, flag revisions, add reviewers, ".
|
|
|
|
"and run build plans.");
|
|
|
|
}
|
|
|
|
|
2013-12-30 16:48:07 -08:00
|
|
|
public function supportsRuleType($rule_type) {
|
|
|
|
switch ($rule_type) {
|
|
|
|
case HeraldRuleTypeConfig::RULE_TYPE_GLOBAL:
|
|
|
|
case HeraldRuleTypeConfig::RULE_TYPE_PERSONAL:
|
|
|
|
return true;
|
|
|
|
case HeraldRuleTypeConfig::RULE_TYPE_OBJECT:
|
|
|
|
default:
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-02 10:25:45 -07:00
|
|
|
public function getFields() {
|
2013-10-03 17:53:12 -07:00
|
|
|
return array_merge(
|
|
|
|
array(
|
|
|
|
self::FIELD_TITLE,
|
|
|
|
self::FIELD_BODY,
|
|
|
|
self::FIELD_AUTHOR,
|
2013-10-05 12:04:31 -07:00
|
|
|
self::FIELD_AUTHOR_PROJECTS,
|
2013-10-03 17:53:12 -07:00
|
|
|
self::FIELD_REVIEWERS,
|
|
|
|
self::FIELD_CC,
|
|
|
|
self::FIELD_REPOSITORY,
|
2014-01-09 15:56:24 -08:00
|
|
|
self::FIELD_REPOSITORY_PROJECTS,
|
2013-10-03 17:53:12 -07:00
|
|
|
self::FIELD_DIFF_FILE,
|
|
|
|
self::FIELD_DIFF_CONTENT,
|
2013-10-04 06:37:32 -07:00
|
|
|
self::FIELD_DIFF_ADDED_CONTENT,
|
|
|
|
self::FIELD_DIFF_REMOVED_CONTENT,
|
2013-10-03 17:53:12 -07:00
|
|
|
self::FIELD_AFFECTED_PACKAGE,
|
|
|
|
self::FIELD_AFFECTED_PACKAGE_OWNER,
|
2014-02-06 12:43:36 -08:00
|
|
|
self::FIELD_IS_NEW_OBJECT,
|
2014-03-11 13:15:01 -07:00
|
|
|
self::FIELD_ARCANIST_PROJECT,
|
2013-10-03 17:53:12 -07:00
|
|
|
),
|
|
|
|
parent::getFields());
|
2013-08-02 10:25:45 -07:00
|
|
|
}
|
|
|
|
|
2013-08-02 12:35:33 -07:00
|
|
|
public function getRepetitionOptions() {
|
|
|
|
return array(
|
|
|
|
HeraldRepetitionPolicyConfig::EVERY,
|
|
|
|
HeraldRepetitionPolicyConfig::FIRST,
|
|
|
|
);
|
|
|
|
}
|
2013-08-02 10:25:45 -07:00
|
|
|
|
2013-08-02 08:55:13 -07:00
|
|
|
public static function newLegacyAdapter(
|
2011-04-05 20:49:31 -07:00
|
|
|
DifferentialRevision $revision,
|
|
|
|
DifferentialDiff $diff) {
|
2013-08-02 08:55:13 -07:00
|
|
|
$object = new HeraldDifferentialRevisionAdapter();
|
|
|
|
|
2013-10-04 16:30:43 -07:00
|
|
|
// Reload the revision to pick up relationship information.
|
|
|
|
$revision = id(new DifferentialRevisionQuery())
|
|
|
|
->withIDs(array($revision->getID()))
|
|
|
|
->setViewer(PhabricatorUser::getOmnipotentUser())
|
|
|
|
->needRelationships(true)
|
|
|
|
->needReviewerStatus(true)
|
|
|
|
->executeOne();
|
|
|
|
|
2013-08-02 08:55:13 -07:00
|
|
|
$object->revision = $revision;
|
|
|
|
$object->diff = $diff;
|
|
|
|
|
|
|
|
return $object;
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public function setExplicitCCs($explicit_ccs) {
|
|
|
|
$this->explicitCCs = $explicit_ccs;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setExplicitReviewers($explicit_reviewers) {
|
|
|
|
$this->explicitReviewers = $explicit_reviewers;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setForbiddenCCs($forbidden_ccs) {
|
|
|
|
$this->forbiddenCCs = $forbidden_ccs;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCCsAddedByHerald() {
|
|
|
|
return array_diff_key($this->newCCs, $this->remCCs);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getCCsRemovedByHerald() {
|
|
|
|
return $this->remCCs;
|
|
|
|
}
|
|
|
|
|
2011-05-27 15:52:26 -07:00
|
|
|
public function getEmailPHIDsAddedByHerald() {
|
|
|
|
return $this->emailPHIDs;
|
|
|
|
}
|
|
|
|
|
2013-10-05 10:36:26 -07:00
|
|
|
public function getReviewersAddedByHerald() {
|
|
|
|
return $this->addReviewerPHIDs;
|
|
|
|
}
|
|
|
|
|
2013-10-06 17:09:24 -07:00
|
|
|
public function getBlockingReviewersAddedByHerald() {
|
|
|
|
return $this->blockingReviewerPHIDs;
|
|
|
|
}
|
|
|
|
|
2013-11-08 16:48:17 -08:00
|
|
|
public function getBuildPlans() {
|
|
|
|
return $this->buildPlans;
|
|
|
|
}
|
|
|
|
|
2011-03-24 21:32:26 -07:00
|
|
|
public function getPHID() {
|
|
|
|
return $this->revision->getPHID();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getHeraldName() {
|
|
|
|
return $this->revision->getTitle();
|
|
|
|
}
|
|
|
|
|
2011-04-05 20:49:31 -07:00
|
|
|
public function loadRepository() {
|
|
|
|
if ($this->repository === null) {
|
2013-09-26 15:28:42 -07:00
|
|
|
$this->repository = false;
|
2014-03-21 14:39:56 -07:00
|
|
|
$repository_phid = $this->getObject()->getRepositoryPHID();
|
2014-01-09 15:56:24 -08:00
|
|
|
if ($repository_phid) {
|
|
|
|
$repository = id(new PhabricatorRepositoryQuery())
|
2014-03-21 14:39:56 -07:00
|
|
|
->setViewer(PhabricatorUser::getOmnipotentUser())
|
2014-01-09 15:56:24 -08:00
|
|
|
->withPHIDs(array($repository_phid))
|
|
|
|
->needProjectPHIDs(true)
|
|
|
|
->executeOne();
|
|
|
|
if ($repository) {
|
|
|
|
$this->repository = $repository;
|
|
|
|
}
|
2011-04-05 20:49:31 -07:00
|
|
|
}
|
|
|
|
}
|
2014-01-09 15:56:24 -08:00
|
|
|
|
2011-04-05 20:49:31 -07:00
|
|
|
return $this->repository;
|
|
|
|
}
|
|
|
|
|
2011-03-24 21:32:26 -07:00
|
|
|
protected function loadChangesets() {
|
2011-04-05 20:49:31 -07:00
|
|
|
if ($this->changesets === null) {
|
|
|
|
$this->changesets = $this->diff->loadChangesets();
|
|
|
|
}
|
|
|
|
return $this->changesets;
|
|
|
|
}
|
|
|
|
|
2014-04-14 12:06:26 -07:00
|
|
|
private function loadChangesetsWithHunks() {
|
|
|
|
$changesets = $this->loadChangesets();
|
|
|
|
|
|
|
|
if ($changesets && !$this->haveHunks) {
|
|
|
|
$this->haveHunks = true;
|
|
|
|
|
|
|
|
id(new DifferentialHunkQuery())
|
|
|
|
->setViewer(PhabricatorUser::getOmnipotentUser())
|
|
|
|
->withChangesets($changesets)
|
|
|
|
->needAttachToChangesets(true)
|
|
|
|
->execute();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $changesets;
|
|
|
|
}
|
|
|
|
|
2011-04-05 20:49:31 -07:00
|
|
|
protected function loadAffectedPaths() {
|
|
|
|
$changesets = $this->loadChangesets();
|
|
|
|
|
|
|
|
$paths = array();
|
|
|
|
foreach ($changesets as $changeset) {
|
|
|
|
$paths[] = $this->getAbsoluteRepositoryPathForChangeset($changeset);
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
2011-04-05 20:49:31 -07:00
|
|
|
return $paths;
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
|
2011-04-05 20:49:31 -07:00
|
|
|
protected function getAbsoluteRepositoryPathForChangeset(
|
|
|
|
DifferentialChangeset $changeset) {
|
|
|
|
|
|
|
|
$repository = $this->loadRepository();
|
|
|
|
if (!$repository) {
|
|
|
|
return '/'.ltrim($changeset->getFilename(), '/');
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
2011-04-05 20:49:31 -07:00
|
|
|
|
|
|
|
$diff = $this->diff;
|
|
|
|
|
2012-04-09 23:42:12 -07:00
|
|
|
return $changeset->getAbsoluteRepositoryPath($repository, $diff);
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
|
2011-04-05 20:49:31 -07:00
|
|
|
protected function loadContentDictionary() {
|
2014-04-14 12:06:20 -07:00
|
|
|
$add_lines = DifferentialHunk::FLAG_LINES_ADDED;
|
|
|
|
$rem_lines = DifferentialHunk::FLAG_LINES_REMOVED;
|
|
|
|
$mask = ($add_lines | $rem_lines);
|
|
|
|
return $this->loadContentWithMask($mask);
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
|
2013-10-04 06:37:32 -07:00
|
|
|
protected function loadAddedContentDictionary() {
|
2014-04-14 12:06:20 -07:00
|
|
|
return $this->loadContentWithMask(DifferentialHunk::FLAG_LINES_ADDED);
|
2013-10-04 06:37:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
protected function loadRemovedContentDictionary() {
|
2014-04-14 12:06:20 -07:00
|
|
|
return $this->loadContentWithMask(DifferentialHunk::FLAG_LINES_REMOVED);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function loadContentWithMask($mask) {
|
2014-04-14 12:06:26 -07:00
|
|
|
$changesets = $this->loadChangesetsWithHunks();
|
2013-10-04 06:37:32 -07:00
|
|
|
|
|
|
|
$dict = array();
|
2014-04-14 12:06:26 -07:00
|
|
|
foreach ($changesets as $changeset) {
|
2013-10-04 06:37:32 -07:00
|
|
|
$content = array();
|
2014-04-14 12:06:26 -07:00
|
|
|
foreach ($changeset->getHunks() as $hunk) {
|
2014-04-14 12:06:20 -07:00
|
|
|
$content[] = $hunk->getContentWithMask($mask);
|
2013-10-04 06:37:32 -07:00
|
|
|
}
|
2014-04-14 12:06:26 -07:00
|
|
|
|
|
|
|
$path = $this->getAbsoluteRepositoryPathForChangeset($changeset);
|
2013-10-04 06:37:32 -07:00
|
|
|
$dict[$path] = implode("\n", $content);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $dict;
|
|
|
|
}
|
|
|
|
|
2011-04-05 20:49:31 -07:00
|
|
|
public function loadAffectedPackages() {
|
|
|
|
if ($this->affectedPackages === null) {
|
|
|
|
$this->affectedPackages = array();
|
|
|
|
|
|
|
|
$repository = $this->loadRepository();
|
|
|
|
if ($repository) {
|
|
|
|
$packages = PhabricatorOwnersPackage::loadAffectedPackages(
|
|
|
|
$repository,
|
|
|
|
$this->loadAffectedPaths());
|
|
|
|
$this->affectedPackages = $packages;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->affectedPackages;
|
|
|
|
}
|
|
|
|
|
2011-03-24 21:32:26 -07:00
|
|
|
public function getHeraldField($field) {
|
|
|
|
switch ($field) {
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_TITLE:
|
2011-03-24 21:32:26 -07:00
|
|
|
return $this->revision->getTitle();
|
|
|
|
break;
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_BODY:
|
2011-03-24 21:32:26 -07:00
|
|
|
return $this->revision->getSummary()."\n".
|
|
|
|
$this->revision->getTestPlan();
|
|
|
|
break;
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_AUTHOR:
|
2011-03-24 21:32:26 -07:00
|
|
|
return $this->revision->getAuthorPHID();
|
|
|
|
break;
|
2013-10-05 12:04:31 -07:00
|
|
|
case self::FIELD_AUTHOR_PROJECTS:
|
|
|
|
$author_phid = $this->revision->getAuthorPHID();
|
|
|
|
if (!$author_phid) {
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
|
|
|
$projects = id(new PhabricatorProjectQuery())
|
|
|
|
->setViewer(PhabricatorUser::getOmnipotentUser())
|
|
|
|
->withMemberPHIDs(array($author_phid))
|
|
|
|
->execute();
|
|
|
|
|
|
|
|
return mpull($projects, 'getPHID');
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_DIFF_FILE:
|
2011-04-05 20:49:31 -07:00
|
|
|
return $this->loadAffectedPaths();
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_CC:
|
2011-03-24 21:32:26 -07:00
|
|
|
if (isset($this->explicitCCs)) {
|
|
|
|
return array_keys($this->explicitCCs);
|
|
|
|
} else {
|
|
|
|
return $this->revision->getCCPHIDs();
|
|
|
|
}
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_REVIEWERS:
|
2011-03-24 21:32:26 -07:00
|
|
|
if (isset($this->explicitReviewers)) {
|
|
|
|
return array_keys($this->explicitReviewers);
|
|
|
|
} else {
|
|
|
|
return $this->revision->getReviewers();
|
|
|
|
}
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_REPOSITORY:
|
2011-04-05 20:49:31 -07:00
|
|
|
$repository = $this->loadRepository();
|
2011-03-24 21:32:26 -07:00
|
|
|
if (!$repository) {
|
|
|
|
return null;
|
|
|
|
}
|
2011-04-05 20:49:31 -07:00
|
|
|
return $repository->getPHID();
|
2014-01-09 15:56:24 -08:00
|
|
|
case self::FIELD_REPOSITORY_PROJECTS:
|
|
|
|
$repository = $this->loadRepository();
|
|
|
|
if (!$repository) {
|
2014-01-13 16:08:30 -08:00
|
|
|
return array();
|
2014-01-09 15:56:24 -08:00
|
|
|
}
|
|
|
|
return $repository->getProjectPHIDs();
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_DIFF_CONTENT:
|
2011-04-05 20:49:31 -07:00
|
|
|
return $this->loadContentDictionary();
|
2013-10-04 06:37:32 -07:00
|
|
|
case self::FIELD_DIFF_ADDED_CONTENT:
|
|
|
|
return $this->loadAddedContentDictionary();
|
|
|
|
case self::FIELD_DIFF_REMOVED_CONTENT:
|
|
|
|
return $this->loadRemovedContentDictionary();
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_AFFECTED_PACKAGE:
|
2011-04-05 20:49:31 -07:00
|
|
|
$packages = $this->loadAffectedPackages();
|
|
|
|
return mpull($packages, 'getPHID');
|
2013-08-02 10:54:19 -07:00
|
|
|
case self::FIELD_AFFECTED_PACKAGE_OWNER:
|
2011-04-05 20:49:31 -07:00
|
|
|
$packages = $this->loadAffectedPackages();
|
2012-03-30 15:46:32 -07:00
|
|
|
return PhabricatorOwnersOwner::loadAffiliatedUserPHIDs(
|
|
|
|
mpull($packages, 'getID'));
|
2014-03-11 13:15:01 -07:00
|
|
|
case self::FIELD_ARCANIST_PROJECT:
|
|
|
|
return $this->revision->getArcanistProjectPHID();
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
2013-08-05 10:02:40 -07:00
|
|
|
|
|
|
|
return parent::getHeraldField($field);
|
2013-08-02 11:32:50 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getActions($rule_type) {
|
|
|
|
switch ($rule_type) {
|
|
|
|
case HeraldRuleTypeConfig::RULE_TYPE_GLOBAL:
|
|
|
|
return array(
|
|
|
|
self::ACTION_ADD_CC,
|
|
|
|
self::ACTION_REMOVE_CC,
|
|
|
|
self::ACTION_EMAIL,
|
2013-10-05 10:36:26 -07:00
|
|
|
self::ACTION_ADD_REVIEWERS,
|
2013-10-06 17:09:24 -07:00
|
|
|
self::ACTION_ADD_BLOCKING_REVIEWERS,
|
2013-11-08 16:48:17 -08:00
|
|
|
self::ACTION_APPLY_BUILD_PLANS,
|
2013-08-02 11:32:50 -07:00
|
|
|
self::ACTION_NOTHING,
|
|
|
|
);
|
|
|
|
case HeraldRuleTypeConfig::RULE_TYPE_PERSONAL:
|
|
|
|
return array(
|
|
|
|
self::ACTION_ADD_CC,
|
|
|
|
self::ACTION_REMOVE_CC,
|
|
|
|
self::ACTION_EMAIL,
|
2013-08-06 11:32:13 -07:00
|
|
|
self::ACTION_FLAG,
|
2013-10-05 10:36:26 -07:00
|
|
|
self::ACTION_ADD_REVIEWERS,
|
2013-10-06 17:09:24 -07:00
|
|
|
self::ACTION_ADD_BLOCKING_REVIEWERS,
|
2013-08-02 11:32:50 -07:00
|
|
|
self::ACTION_NOTHING,
|
|
|
|
);
|
|
|
|
}
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public function applyHeraldEffects(array $effects) {
|
2012-03-30 13:51:54 -07:00
|
|
|
assert_instances_of($effects, 'HeraldEffect');
|
|
|
|
|
2011-03-24 21:32:26 -07:00
|
|
|
$result = array();
|
|
|
|
if ($this->explicitCCs) {
|
|
|
|
$effect = new HeraldEffect();
|
2013-08-06 11:23:01 -07:00
|
|
|
$effect->setAction(self::ACTION_ADD_CC);
|
2011-03-24 21:32:26 -07:00
|
|
|
$effect->setTarget(array_keys($this->explicitCCs));
|
|
|
|
$effect->setReason(
|
2013-05-20 08:24:07 -07:00
|
|
|
pht('CCs provided explicitly by revision author or carried over '.
|
|
|
|
'from a previous version of the revision.'));
|
2011-03-24 21:32:26 -07:00
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
2013-05-20 08:24:07 -07:00
|
|
|
pht('Added addresses to CC list.'));
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
$forbidden_ccs = array_fill_keys(
|
|
|
|
nonempty($this->forbiddenCCs, array()),
|
|
|
|
true);
|
|
|
|
|
|
|
|
foreach ($effects as $effect) {
|
|
|
|
$action = $effect->getAction();
|
|
|
|
switch ($action) {
|
2013-08-06 11:23:01 -07:00
|
|
|
case self::ACTION_NOTHING:
|
2011-03-24 21:32:26 -07:00
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
2013-05-20 08:24:07 -07:00
|
|
|
pht('OK, did nothing.'));
|
2011-03-24 21:32:26 -07:00
|
|
|
break;
|
2013-08-06 11:23:01 -07:00
|
|
|
case self::ACTION_FLAG:
|
2012-03-30 13:51:54 -07:00
|
|
|
$result[] = parent::applyFlagEffect(
|
|
|
|
$effect,
|
|
|
|
$this->revision->getPHID());
|
|
|
|
break;
|
2013-08-06 11:23:01 -07:00
|
|
|
case self::ACTION_EMAIL:
|
|
|
|
case self::ACTION_ADD_CC:
|
|
|
|
$op = ($action == self::ACTION_EMAIL) ? 'email' : 'CC';
|
2011-03-24 21:32:26 -07:00
|
|
|
$base_target = $effect->getTarget();
|
|
|
|
$forbidden = array();
|
|
|
|
foreach ($base_target as $key => $fbid) {
|
|
|
|
if (isset($forbidden_ccs[$fbid])) {
|
|
|
|
$forbidden[] = $fbid;
|
|
|
|
unset($base_target[$key]);
|
|
|
|
} else {
|
2013-08-06 11:23:01 -07:00
|
|
|
if ($action == self::ACTION_EMAIL) {
|
2011-05-27 15:52:26 -07:00
|
|
|
$this->emailPHIDs[$fbid] = true;
|
|
|
|
} else {
|
|
|
|
$this->newCCs[$fbid] = true;
|
|
|
|
}
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($forbidden) {
|
|
|
|
$failed = clone $effect;
|
|
|
|
$failed->setTarget($forbidden);
|
|
|
|
if ($base_target) {
|
|
|
|
$effect->setTarget($base_target);
|
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
2013-05-20 08:24:07 -07:00
|
|
|
pht('Added these addresses to %s list. '.
|
|
|
|
'Others could not be added.', $op));
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$failed,
|
|
|
|
false,
|
2013-05-20 08:24:07 -07:00
|
|
|
pht('%s forbidden, these addresses have unsubscribed.', $op));
|
2011-03-24 21:32:26 -07:00
|
|
|
} else {
|
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
2013-05-20 08:24:07 -07:00
|
|
|
pht('Added addresses to %s list.', $op));
|
2011-03-24 21:32:26 -07:00
|
|
|
}
|
|
|
|
break;
|
2013-08-06 11:23:01 -07:00
|
|
|
case self::ACTION_REMOVE_CC:
|
2011-03-24 21:32:26 -07:00
|
|
|
foreach ($effect->getTarget() as $fbid) {
|
|
|
|
$this->remCCs[$fbid] = true;
|
|
|
|
}
|
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
2013-05-20 08:24:07 -07:00
|
|
|
pht('Removed addresses from CC list.'));
|
2011-03-24 21:32:26 -07:00
|
|
|
break;
|
2013-10-05 10:36:26 -07:00
|
|
|
case self::ACTION_ADD_REVIEWERS:
|
|
|
|
foreach ($effect->getTarget() as $phid) {
|
|
|
|
$this->addReviewerPHIDs[$phid] = true;
|
|
|
|
}
|
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
|
|
|
pht('Added reviewers.'));
|
|
|
|
break;
|
2013-10-06 17:09:24 -07:00
|
|
|
case self::ACTION_ADD_BLOCKING_REVIEWERS:
|
|
|
|
// This adds reviewers normally, it just also marks them blocking.
|
|
|
|
foreach ($effect->getTarget() as $phid) {
|
|
|
|
$this->addReviewerPHIDs[$phid] = true;
|
|
|
|
$this->blockingReviewerPHIDs[$phid] = true;
|
|
|
|
}
|
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
|
|
|
pht('Added blocking reviewers.'));
|
|
|
|
break;
|
2013-11-08 16:48:17 -08:00
|
|
|
case self::ACTION_APPLY_BUILD_PLANS:
|
|
|
|
foreach ($effect->getTarget() as $phid) {
|
|
|
|
$this->buildPlans[] = $phid;
|
|
|
|
}
|
|
|
|
$result[] = new HeraldApplyTranscript(
|
|
|
|
$effect,
|
|
|
|
true,
|
|
|
|
pht('Applied build plans.'));
|
|
|
|
break;
|
2011-03-24 21:32:26 -07:00
|
|
|
default:
|
|
|
|
throw new Exception("No rules to handle action '{$action}'.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
}
|