Page MenuHomePhabricator

Expand aggregate email recipients prior to multiplexing
ClosedPublic

Authored by epriestley on Jan 31 2014, 12:29 AM.
Tags
None
Referenced Files
F18773100: D8117.diff
Thu, Oct 9, 7:10 AM
F18771041: D8117.id.diff
Wed, Oct 8, 5:04 PM
F18738173: D8117.id18360.diff
Wed, Oct 1, 2:39 PM
F18734586: D8117.id.diff
Tue, Sep 30, 10:57 PM
F18627501: D8117.id18381.diff
Sep 16 2025, 4:10 AM
F18598015: D8117.diff
Sep 13 2025, 4:10 AM
F18360156: D8117.diff
Aug 27 2025, 10:15 AM
F18300478: D8117.id18360.diff
Aug 23 2025, 7:06 PM
Subscribers
Tokens
"Mountain of Wealth" token, awarded by dctrwatson.

Details

Summary

Ref T4361. Before we figure out which To/CC are addressable, try to expand To/CC. Specifically, the supported expansion right now is project PHIDs expanding to all their members.

Because of the way multiplexing works, we have to do this in two places: explicitly in multiplexMail(), and when sending mail that wasn't multiplexed. This is messy; eventually we can get rid of it (after ApplicationTransactions are everywhere).

This has some rough edges, but should basically give us what we need to make stuff like projects mailable. Particularly, it deals with most issues in D7436:

  • I got around the resolution/multiplexing issue by resolving aggregate mailables separately from mailable actors.
  • We get to keep the Project PHID as a To/CC/Reviewer/Whatever until the last second.
  • Users won't get two emails for being a CC and also a member of a CC'd project.
  • We can degrade to the list stuff this way if we want, by having the project aggregate yield a single list PHID.
Test Plan

Added a comment to a revision with a project reviewer, got mail to all the project's members.

Diff Detail

Repository
rP Phabricator
Branch
mta2
Lint
Lint Passed
Unit
Tests Passed