1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 23:31:03 +01:00

Use object PHIDs for "Thread-Topic" headers in mail

Summary:
Depends on D19009. Ref T13053. For "Must Encrypt" mail, we must currently strip the "Thread-Topic" header because it sometimes contains sensitive information about the object.

I don't actually know if this header is useful or anyting uses it. My understanding is that it's an Outlook/Exchange thing, but we also implement "Thread-Index" which I think is what Outlook/Exchange actually look at. This header may have done something before we implemented "Thread-Index", or maybe never done anything. Or maybe older versions of Excel/Outlook did something with it and newer versions don't, or do less. So it's possible that an even better fix here would be to simply remove this, but I wasn't able to convince myself of that after Googling for 10 minutes and I don't think it's worth hours of installing Exchange/Outlook to figure out. Instead, I'm just trying to simplify our handling of this header for now, and maybe some day we'll learn more about Exchange/Outlook and can remove it.

In a number of cases we already use the object monogram or PHID as a "Thread-Topic" without users ever complaining, so I think that if this header is useful it probably isn't shown to users, or isn't shown very often (e.g., only in a specific "conversation" sub-view?). Just use the object PHID (which should be unique and stable) as a thread-topic, everywhere, automatically.

Then allow this header through for "Must Encrypt" mail.

Test Plan: Processed some local mail, saw object PHIDs for "Thread-Topic" headers.

Reviewers: amckinley

Maniphest Tasks: T13053

Differential Revision: https://secure.phabricator.com/D19012
This commit is contained in:
epriestley 2018-02-07 02:57:28 -08:00
parent 19b3fb8863
commit f090fa7426
27 changed files with 31 additions and 70 deletions

View file

@ -473,17 +473,14 @@ final class PhabricatorAuditEditor
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$identifier = $object->getCommitIdentifier(); $identifier = $object->getCommitIdentifier();
$repository = $object->getRepository(); $repository = $object->getRepository();
$monogram = $repository->getMonogram();
$summary = $object->getSummary(); $summary = $object->getSummary();
$name = $repository->formatCommitName($identifier); $name = $repository->formatCommitName($identifier);
$subject = "{$name}: {$summary}"; $subject = "{$name}: {$summary}";
$thread_topic = "Commit {$monogram}{$identifier}";
$template = id(new PhabricatorMetaMTAMail()) $template = id(new PhabricatorMetaMTAMail())
->setSubject($subject) ->setSubject($subject);
->addHeader('Thread-Topic', $thread_topic);
$this->attachPatch( $this->attachPatch(
$template, $template,

View file

@ -255,11 +255,9 @@ final class PhabricatorAuthSSHKeyEditor
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID(); $id = $object->getID();
$name = $object->getName(); $name = $object->getName();
$phid = $object->getPHID();
$mail = id(new PhabricatorMetaMTAMail()) $mail = id(new PhabricatorMetaMTAMail())
->setSubject(pht('SSH Key %d: %s', $id, $name)) ->setSubject(pht('SSH Key %d: %s', $id, $name));
->addHeader('Thread-Topic', $phid);
// The primary value of this mail is alerting users to account compromises, // The primary value of this mail is alerting users to account compromises,
// so force delivery. In particular, this mail should still be delivered // so force delivery. In particular, this mail should still be delivered

View file

@ -87,12 +87,10 @@ final class PhabricatorBadgesEditor
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$name = $object->getName(); $name = $object->getName();
$id = $object->getID(); $id = $object->getID();
$topic = pht('Badge %d', $id);
$subject = pht('Badge %d: %s', $id, $name); $subject = pht('Badge %d: %s', $id, $name);
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject($subject) ->setSubject($subject);
->addHeader('Thread-Topic', $topic);
} }
protected function getMailTo(PhabricatorLiskDAO $object) { protected function getMailTo(PhabricatorLiskDAO $object) {

View file

@ -309,13 +309,11 @@ final class PhabricatorCalendarEventEditor
} }
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID();
$name = $object->getName(); $name = $object->getName();
$monogram = $object->getMonogram(); $monogram = $object->getMonogram();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("{$monogram}: {$name}") ->setSubject("{$monogram}: {$name}");
->addHeader('Thread-Topic', $monogram);
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -227,11 +227,9 @@ final class ConpherenceEditor extends PhabricatorApplicationTransactionEditor {
'%s sent you a message.', '%s sent you a message.',
$this->getActor()->getUserName()); $this->getActor()->getUserName());
} }
$phid = $object->getPHID();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("Z{$id}: {$title}") ->setSubject("Z{$id}: {$title}");
->addHeader('Thread-Topic', "Z{$id}: {$phid}");
} }
protected function getMailTo(PhabricatorLiskDAO $object) { protected function getMailTo(PhabricatorLiskDAO $object) {

View file

@ -45,8 +45,7 @@ final class PhabricatorCountdownEditor
$name = $object->getTitle(); $name = $object->getTitle();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("{$monogram}: {$name}") ->setSubject("{$monogram}: {$name}");
->addHeader('Thread-Topic', $monogram);
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -689,15 +689,10 @@ final class DifferentialTransactionEditor
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID(); $id = $object->getID();
$title = $object->getTitle(); $title = $object->getTitle();
$original_title = $object->getOriginalTitle();
$subject = "D{$id}: {$title}"; $subject = "D{$id}: {$title}";
$thread_topic = "D{$id}: {$original_title}";
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject($subject) ->setSubject($subject);
->addHeader('Thread-Topic', $thread_topic);
} }
protected function getTransactionsForMail( protected function getTransactionsForMail(

View file

@ -47,8 +47,7 @@ final class PhabricatorFileEditor
$name = $object->getName(); $name = $object->getName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("F{$id}: {$name}") ->setSubject("F{$id}: {$name}");
->addHeader('Thread-Topic', "F{$id}");
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -50,8 +50,7 @@ final class FundInitiativeEditor
$name = $object->getName(); $name = $object->getName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("{$monogram}: {$name}") ->setSubject("{$monogram}: {$name}");
->addHeader('Thread-Topic', $monogram);
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -124,12 +124,10 @@ final class LegalpadDocumentEditor
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID(); $id = $object->getID();
$phid = $object->getPHID();
$title = $object->getDocumentBody()->getTitle(); $title = $object->getDocumentBody()->getTitle();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("L{$id}: {$title}") ->setSubject("L{$id}: {$title}");
->addHeader('Thread-Topic', "L{$id}: {$phid}");
} }
protected function getMailTo(PhabricatorLiskDAO $object) { protected function getMailTo(PhabricatorLiskDAO $object) {

View file

@ -35,8 +35,7 @@ final class PhabricatorMacroEditor
$name = 'Image Macro "'.$name.'"'; $name = 'Image Macro "'.$name.'"';
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject($name) ->setSubject($name);
->addHeader('Thread-Topic', $name);
} }
protected function getMailTo(PhabricatorLiskDAO $object) { protected function getMailTo(PhabricatorLiskDAO $object) {

View file

@ -206,8 +206,7 @@ final class ManiphestTransactionEditor
$title = $object->getTitle(); $title = $object->getTitle();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("T{$id}: {$title}") ->setSubject("T{$id}: {$title}");
->addHeader('Thread-Topic', "T{$id}: ".$object->getOriginalTitle());
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -1262,6 +1262,11 @@ final class PhabricatorMetaMTAMail
$headers[] = array('X-Phabricator-Must-Encrypt', 'Yes'); $headers[] = array('X-Phabricator-Must-Encrypt', 'Yes');
} }
$related_phid = $this->getRelatedPHID();
if ($related_phid) {
$headers[] = array('Thread-Topic', $related_phid);
}
return $headers; return $headers;
} }
@ -1309,6 +1314,7 @@ final class PhabricatorMetaMTAMail
'Precedence', 'Precedence',
'References', 'References',
'Thread-Index', 'Thread-Index',
'Thread-Topic',
'X-Mail-Transport-Agent', 'X-Mail-Transport-Agent',
'X-Auto-Response-Suppress', 'X-Auto-Response-Suppress',

View file

@ -46,12 +46,10 @@ final class PhabricatorOwnersPackageTransactionEditor
} }
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID();
$name = $object->getName(); $name = $object->getName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject($name) ->setSubject($name);
->addHeader('Thread-Topic', $object->getPHID());
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -72,8 +72,7 @@ final class PhabricatorPasteEditor
$name = $object->getTitle(); $name = $object->getTitle();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("P{$id}: {$name}") ->setSubject("P{$id}: {$name}");
->addHeader('Thread-Topic', "P{$id}");
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -48,12 +48,10 @@ final class PhameBlogEditor
} }
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$phid = $object->getPHID();
$name = $object->getName(); $name = $object->getName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject($name) ->setSubject($name);
->addHeader('Thread-Topic', $phid);
} }
protected function buildReplyHandler(PhabricatorLiskDAO $object) { protected function buildReplyHandler(PhabricatorLiskDAO $object) {

View file

@ -61,12 +61,10 @@ final class PhamePostEditor
} }
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$phid = $object->getPHID();
$title = $object->getTitle(); $title = $object->getTitle();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject($title) ->setSubject($title);
->addHeader('Thread-Topic', $phid);
} }
protected function buildReplyHandler(PhabricatorLiskDAO $object) { protected function buildReplyHandler(PhabricatorLiskDAO $object) {

View file

@ -112,11 +112,9 @@ final class PholioMockEditor extends PhabricatorApplicationTransactionEditor {
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID(); $id = $object->getID();
$name = $object->getName(); $name = $object->getName();
$original_name = $object->getOriginalName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("M{$id}: {$name}") ->setSubject("M{$id}: {$name}");
->addHeader('Thread-Topic', "M{$id}: {$original_name}");
} }
protected function getMailTo(PhabricatorLiskDAO $object) { protected function getMailTo(PhabricatorLiskDAO $object) {

View file

@ -123,8 +123,7 @@ final class PhortuneCartEditor
$name = $object->getName(); $name = $object->getName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject(pht('Order %d: %s', $id, $name)) ->setSubject(pht('Order %d: %s', $id, $name));
->addHeader('Thread-Topic', pht('Order %s', $id));
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -299,12 +299,10 @@ final class PhrictionTransactionEditor
} }
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID();
$title = $object->getContent()->getTitle(); $title = $object->getContent()->getTitle();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject($title) ->setSubject($title);
->addHeader('Thread-Topic', $object->getPHID());
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -68,8 +68,7 @@ final class PhabricatorPhurlURLEditor
$name = $object->getName(); $name = $object->getName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("U{$id}: {$name}") ->setSubject("U{$id}: {$name}");
->addHeader('Thread-Topic', "U{$id}: ".$object->getName());
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -57,8 +57,7 @@ final class PonderAnswerEditor extends PonderEditor {
$id = $object->getID(); $id = $object->getID();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("ANSR{$id}") ->setSubject("ANSR{$id}");
->addHeader('Thread-Topic', "ANSR{$id}");
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -146,11 +146,9 @@ final class PonderQuestionEditor
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID(); $id = $object->getID();
$title = $object->getTitle(); $title = $object->getTitle();
$original_title = $object->getOriginalTitle();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("Q{$id}: {$title}") ->setSubject("Q{$id}: {$title}");
->addHeader('Thread-Topic', "Q{$id}: {$original_title}");
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -219,12 +219,10 @@ final class PhabricatorProjectTransactionEditor
} }
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID();
$name = $object->getName(); $name = $object->getName();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("{$name}") ->setSubject("{$name}");
->addHeader('Thread-Topic', "Project {$id}");
} }
protected function buildMailBody( protected function buildMailBody(

View file

@ -196,11 +196,9 @@ final class ReleephRequestTransactionalEditor
protected function buildMailTemplate(PhabricatorLiskDAO $object) { protected function buildMailTemplate(PhabricatorLiskDAO $object) {
$id = $object->getID(); $id = $object->getID();
$phid = $object->getPHID();
$title = $object->getSummaryForDisplay(); $title = $object->getSummaryForDisplay();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("RQ{$id}: {$title}") ->setSubject("RQ{$id}: {$title}");
->addHeader('Thread-Topic', "RQ{$id}: {$phid}");
} }
protected function getMailTo(PhabricatorLiskDAO $object) { protected function getMailTo(PhabricatorLiskDAO $object) {

View file

@ -124,7 +124,6 @@ final class PhabricatorRepositoryPushMailWorker
->setFrom($event->getPusherPHID()) ->setFrom($event->getPusherPHID())
->setBody($body->render()) ->setBody($body->render())
->setThreadID($event->getPHID(), $is_new = true) ->setThreadID($event->getPHID(), $is_new = true)
->addHeader('Thread-Topic', $subject)
->setIsBulk(true); ->setIsBulk(true);
return $target->willSendMail($mail); return $target->willSendMail($mail);

View file

@ -48,8 +48,7 @@ final class PhabricatorSlowvoteEditor
$name = $object->getQuestion(); $name = $object->getQuestion();
return id(new PhabricatorMetaMTAMail()) return id(new PhabricatorMetaMTAMail())
->setSubject("{$monogram}: {$name}") ->setSubject("{$monogram}: {$name}");
->addHeader('Thread-Topic', $monogram);
} }
protected function buildMailBody( protected function buildMailBody(