1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-02 02:40:58 +01:00

Don't try to implicitly subscribe users who are already subscribed

Summary:
Fixes T2587. Specifically:

  - Don't try to implicitly subscribe the actor if they're already subscribed.
  - Since there are like 5 things that need to interact with subscribers, just load them once upfront for Subscribable objects.

Test Plan: Made a comment on a mock I was CC'd on without an error.

Reviewers: vrana

Reviewed By: vrana

CC: aran

Maniphest Tasks: T2587

Differential Revision: https://secure.phabricator.com/D5091
This commit is contained in:
epriestley 2013-02-22 15:54:56 -08:00
parent cebe6ac387
commit bd95121b33

View file

@ -16,6 +16,7 @@ abstract class PhabricatorApplicationTransactionEditor
private $mentionedPHIDs; private $mentionedPHIDs;
private $continueOnNoEffect; private $continueOnNoEffect;
private $parentMessageID; private $parentMessageID;
private $subscribers;
private $isPreview; private $isPreview;
@ -95,13 +96,7 @@ abstract class PhabricatorApplicationTransactionEditor
PhabricatorApplicationTransaction $xaction) { PhabricatorApplicationTransaction $xaction) {
switch ($xaction->getTransactionType()) { switch ($xaction->getTransactionType()) {
case PhabricatorTransactions::TYPE_SUBSCRIBERS: case PhabricatorTransactions::TYPE_SUBSCRIBERS:
if ($object->getPHID()) { return array_values($this->subscribers);
$old_phids = PhabricatorSubscribersQuery::loadSubscribersForPHID(
$object->getPHID());
} else {
$old_phids = array();
}
return array_values($old_phids);
case PhabricatorTransactions::TYPE_VIEW_POLICY: case PhabricatorTransactions::TYPE_VIEW_POLICY:
return $object->getViewPolicy(); return $object->getViewPolicy();
case PhabricatorTransactions::TYPE_EDIT_POLICY: case PhabricatorTransactions::TYPE_EDIT_POLICY:
@ -222,6 +217,15 @@ abstract class PhabricatorApplicationTransactionEditor
$actor = $this->requireActor(); $actor = $this->requireActor();
if ($object->getPHID() &&
($object instanceof PhabricatorSubscribableInterface)) {
$subs = PhabricatorSubscribersQuery::loadSubscribersForPHID(
$object->getPHID());
$this->subscribers = array_fuse($subs);
} else {
$this->subscribers = array();
}
$xactions = $this->applyImplicitCC($object, $xactions); $xactions = $this->applyImplicitCC($object, $xactions);
$mention_xaction = $this->buildMentionTransaction($object, $xactions); $mention_xaction = $this->buildMentionTransaction($object, $xactions);
@ -422,9 +426,7 @@ abstract class PhabricatorApplicationTransactionEditor
// Don't try to subscribe already-subscribed mentions: we want to generate // Don't try to subscribe already-subscribed mentions: we want to generate
// a dialog about an action having no effect if the user explicitly adds // a dialog about an action having no effect if the user explicitly adds
// existing CCs, but not if they merely mention existing subscribers. // existing CCs, but not if they merely mention existing subscribers.
$current = PhabricatorSubscribersQuery::loadSubscribersForPHID( $phids = array_diff($phids, $this->subscribers);
$object->getPHID());
$phids = array_diff($phids, $current);
} }
if (!$phids) { if (!$phids) {
@ -678,6 +680,11 @@ abstract class PhabricatorApplicationTransactionEditor
} }
if ($object->getPHID()) { if ($object->getPHID()) {
if (isset($this->subscribers[$actor_phid])) {
// If the user is already subscribed, don't implicitly CC them.
return $xactions;
}
$unsub = PhabricatorEdgeQuery::loadDestinationPHIDs( $unsub = PhabricatorEdgeQuery::loadDestinationPHIDs(
$object->getPHID(), $object->getPHID(),
PhabricatorEdgeConfig::TYPE_OBJECT_HAS_UNSUBSCRIBER); PhabricatorEdgeConfig::TYPE_OBJECT_HAS_UNSUBSCRIBER);
@ -840,8 +847,7 @@ abstract class PhabricatorApplicationTransactionEditor
*/ */
protected function getMailCC(PhabricatorLiskDAO $object) { protected function getMailCC(PhabricatorLiskDAO $object) {
if ($object instanceof PhabricatorSubscribableInterface) { if ($object instanceof PhabricatorSubscribableInterface) {
$phid = $object->getPHID(); return $this->subscribers;
return PhabricatorSubscribersQuery::loadSubscribersForPHID($phid);
} }
throw new Exception("Capability not supported."); throw new Exception("Capability not supported.");
} }