diff --git a/src/applications/feed/PhabricatorFeedStoryPublisher.php b/src/applications/feed/PhabricatorFeedStoryPublisher.php index 2d54e4a567..d80073980b 100644 --- a/src/applications/feed/PhabricatorFeedStoryPublisher.php +++ b/src/applications/feed/PhabricatorFeedStoryPublisher.php @@ -104,35 +104,39 @@ final class PhabricatorFeedStoryPublisher { private function insertNotifications($chrono_key) { + if (!$this->subscribedPHIDs) { + return; + } + if (!$this->primaryObjectPHID) { - throw - new Exception("Call setPrimaryObjectPHID() before Publishing!"); + throw new Exception( + "You must call setPrimaryObjectPHID() if you setSubscribedPHIDs()!"); } - if ($this->subscribedPHIDs) { - $notif = new PhabricatorFeedStoryNotification(); - $sql = array(); - $conn = $notif->establishConnection('w'); - foreach (array_unique($this->subscribedPHIDs) as $user_phid) { - $sql[] = qsprintf( - $conn, - '(%s, %s, %s, %d)', - $this->primaryObjectPHID, - $user_phid, - $chrono_key, - 0); - } + $notif = new PhabricatorFeedStoryNotification(); + $sql = array(); + $conn = $notif->establishConnection('w'); - queryfx( + foreach (array_unique($this->subscribedPHIDs) as $user_phid) { + $sql[] = qsprintf( $conn, - 'INSERT INTO %T - (primaryObjectPHID, userPHID, chronologicalKey, hasViewed) - VALUES %Q', - $notif->getTableName(), - implode(', ', $sql)); + '(%s, %s, %s, %d)', + $this->primaryObjectPHID, + $user_phid, + $chrono_key, + 0); } + queryfx( + $conn, + 'INSERT INTO %T + (primaryObjectPHID, userPHID, chronologicalKey, hasViewed) + VALUES %Q', + $notif->getTableName(), + implode(', ', $sql)); } + + /** * We generate a unique chronological key for each story type because we want * to be able to page through the stream with a cursor (i.e., select stories