2011-05-04 23:09:42 -07:00
|
|
|
<?php
|
|
|
|
|
2012-03-13 16:21:04 -07:00
|
|
|
final class PhabricatorMetaMTAReceivedMail extends PhabricatorMetaMTADAO {
|
2011-05-04 23:09:42 -07:00
|
|
|
|
|
|
|
protected $headers = array();
|
|
|
|
protected $bodies = array();
|
|
|
|
protected $attachments = array();
|
2013-05-13 16:32:19 -07:00
|
|
|
protected $status = '';
|
2011-05-04 23:09:42 -07:00
|
|
|
|
|
|
|
protected $relatedPHID;
|
|
|
|
protected $authorPHID;
|
|
|
|
protected $message;
|
2013-05-13 16:32:19 -07:00
|
|
|
protected $messageIDHash = '';
|
2011-05-04 23:09:42 -07:00
|
|
|
|
|
|
|
public function getConfiguration() {
|
|
|
|
return array(
|
|
|
|
self::CONFIG_SERIALIZATION => array(
|
|
|
|
'headers' => self::SERIALIZATION_JSON,
|
|
|
|
'bodies' => self::SERIALIZATION_JSON,
|
|
|
|
'attachments' => self::SERIALIZATION_JSON,
|
|
|
|
),
|
|
|
|
) + parent::getConfiguration();
|
|
|
|
}
|
|
|
|
|
2011-05-30 11:07:05 -07:00
|
|
|
public function setHeaders(array $headers) {
|
|
|
|
// Normalize headers to lowercase.
|
|
|
|
$normalized = array();
|
|
|
|
foreach ($headers as $name => $value) {
|
2013-05-13 16:32:19 -07:00
|
|
|
$name = $this->normalizeMailHeaderName($name);
|
|
|
|
if ($name == 'message-id') {
|
|
|
|
$this->setMessageIDHash(PhabricatorHash::digestForIndex($value));
|
|
|
|
}
|
|
|
|
$normalized[$name] = $value;
|
2011-05-30 11:07:05 -07:00
|
|
|
}
|
|
|
|
$this->headers = $normalized;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-05-13 16:32:19 -07:00
|
|
|
public function getHeader($key, $default = null) {
|
|
|
|
$key = $this->normalizeMailHeaderName($key);
|
|
|
|
return idx($this->headers, $key, $default);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function normalizeMailHeaderName($name) {
|
|
|
|
return strtolower($name);
|
|
|
|
}
|
|
|
|
|
2011-06-22 12:41:19 -07:00
|
|
|
public function getMessageID() {
|
2013-05-13 16:32:19 -07:00
|
|
|
return $this->getHeader('Message-ID');
|
2011-06-22 12:41:19 -07:00
|
|
|
}
|
|
|
|
|
2011-07-04 09:45:42 -07:00
|
|
|
public function getSubject() {
|
2013-05-13 16:32:19 -07:00
|
|
|
return $this->getHeader('Subject');
|
2011-07-04 09:45:42 -07:00
|
|
|
}
|
|
|
|
|
2012-08-28 14:09:37 -07:00
|
|
|
public function getCCAddresses() {
|
|
|
|
return $this->getRawEmailAddresses(idx($this->headers, 'cc'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getToAddresses() {
|
|
|
|
return $this->getRawEmailAddresses(idx($this->headers, 'to'));
|
|
|
|
}
|
|
|
|
|
2013-05-17 03:51:57 -07:00
|
|
|
public function loadExcludeMailRecipientPHIDs() {
|
2012-10-10 10:18:23 -07:00
|
|
|
$addresses = array_merge(
|
|
|
|
$this->getToAddresses(),
|
2013-02-19 13:33:10 -08:00
|
|
|
$this->getCCAddresses());
|
2012-10-10 10:18:23 -07:00
|
|
|
|
2012-11-01 15:18:06 -07:00
|
|
|
return $this->loadPHIDsFromAddresses($addresses);
|
|
|
|
}
|
|
|
|
|
|
|
|
final public function loadCCPHIDs() {
|
|
|
|
return $this->loadPHIDsFromAddresses($this->getCCAddresses());
|
|
|
|
}
|
|
|
|
|
|
|
|
private function loadPHIDsFromAddresses(array $addresses) {
|
2012-11-16 06:56:44 -08:00
|
|
|
if (empty($addresses)) {
|
|
|
|
return array();
|
|
|
|
}
|
2012-10-10 10:18:23 -07:00
|
|
|
$users = id(new PhabricatorUserEmail())
|
|
|
|
->loadAllWhere('address IN (%Ls)', $addresses);
|
|
|
|
$user_phids = mpull($users, 'getUserPHID');
|
|
|
|
|
|
|
|
$mailing_lists = id(new PhabricatorMetaMTAMailingList())
|
|
|
|
->loadAllWhere('email in (%Ls)', $addresses);
|
|
|
|
$mailing_list_phids = mpull($mailing_lists, 'getPHID');
|
|
|
|
|
|
|
|
return array_merge($user_phids, $mailing_list_phids);
|
|
|
|
}
|
|
|
|
|
2011-05-04 23:09:42 -07:00
|
|
|
public function processReceivedMail() {
|
2012-05-22 06:02:05 -07:00
|
|
|
|
2013-05-13 16:32:19 -07:00
|
|
|
try {
|
|
|
|
$this->dropMailFromPhabricator();
|
|
|
|
$this->dropMailAlreadyReceived();
|
2013-05-14 10:57:41 -07:00
|
|
|
|
|
|
|
$receiver = $this->loadReceiver();
|
2013-05-15 08:44:54 -07:00
|
|
|
$sender = $receiver->loadSender($this);
|
2013-05-17 03:49:29 -07:00
|
|
|
$receiver->validateSender($this, $sender);
|
2013-05-14 10:57:41 -07:00
|
|
|
|
2013-05-17 03:51:57 -07:00
|
|
|
$this->setAuthorPHID($sender->getPHID());
|
|
|
|
|
2013-05-17 10:00:49 -07:00
|
|
|
$receiver->receiveMail($this, $sender);
|
2013-05-13 16:32:19 -07:00
|
|
|
} catch (PhabricatorMetaMTAReceivedMailProcessingException $ex) {
|
When we fail to process mail, tell the user about it
Summary:
Ref T4371. Ref T4699. Fixes T3994.
Currently, we're very conservative about sending errors back to users. A concern I had about this was that mistakes could lead to email loops, massive amounts of email spam, etc. Because of this, I was pretty hesitant about replying to email with more email when I wrote this stuff.
However, this was a long time ago. We now have Message-ID deduplication, "X-Phabricator-Sent-This-Mail", generally better mail infrastructure, and rate limiting. Together, these mechanisms should reasonably prevent anything crazy (primarily, infinite email loops) from happening.
Thus:
- When we hit any processing error after receiving a mail, try to send the author a reply with details about what went wrong. These are limited to 6 per hour per address.
- Rewrite most of the errors to be more detailed and informative.
- Rewrite most of the errors in a user-facing voice ("You sent this mail..." instead of "This mail was sent..").
- Remove the redundant, less sophisticated code which does something similar in Differential.
Test Plan:
- Using `scripts/mail/mail_receiver.php`, artificially received a pile of mail.
- Hit a bunch of different errors.
- Saw reasonable error mail get sent to me.
- Saw other reasonable error mail get rate limited.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T3994, T4371, T4699
Differential Revision: https://secure.phabricator.com/D8692
2014-04-03 18:43:18 -07:00
|
|
|
switch ($ex->getStatusCode()) {
|
|
|
|
case MetaMTAReceivedMailStatus::STATUS_DUPLICATE:
|
|
|
|
case MetaMTAReceivedMailStatus::STATUS_FROM_PHABRICATOR:
|
|
|
|
// Don't send an error email back in these cases, since they're
|
|
|
|
// very unlikely to be the sender's fault.
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$this->sendExceptionMail($ex);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2013-05-13 16:32:19 -07:00
|
|
|
$this
|
|
|
|
->setStatus($ex->getStatusCode())
|
|
|
|
->setMessage($ex->getMessage())
|
|
|
|
->save();
|
|
|
|
return $this;
|
2013-05-17 10:00:49 -07:00
|
|
|
} catch (Exception $ex) {
|
When we fail to process mail, tell the user about it
Summary:
Ref T4371. Ref T4699. Fixes T3994.
Currently, we're very conservative about sending errors back to users. A concern I had about this was that mistakes could lead to email loops, massive amounts of email spam, etc. Because of this, I was pretty hesitant about replying to email with more email when I wrote this stuff.
However, this was a long time ago. We now have Message-ID deduplication, "X-Phabricator-Sent-This-Mail", generally better mail infrastructure, and rate limiting. Together, these mechanisms should reasonably prevent anything crazy (primarily, infinite email loops) from happening.
Thus:
- When we hit any processing error after receiving a mail, try to send the author a reply with details about what went wrong. These are limited to 6 per hour per address.
- Rewrite most of the errors to be more detailed and informative.
- Rewrite most of the errors in a user-facing voice ("You sent this mail..." instead of "This mail was sent..").
- Remove the redundant, less sophisticated code which does something similar in Differential.
Test Plan:
- Using `scripts/mail/mail_receiver.php`, artificially received a pile of mail.
- Hit a bunch of different errors.
- Saw reasonable error mail get sent to me.
- Saw other reasonable error mail get rate limited.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T3994, T4371, T4699
Differential Revision: https://secure.phabricator.com/D8692
2014-04-03 18:43:18 -07:00
|
|
|
$this->sendExceptionMail($ex);
|
|
|
|
|
2013-05-17 10:00:49 -07:00
|
|
|
$this
|
|
|
|
->setStatus(MetaMTAReceivedMailStatus::STATUS_UNHANDLED_EXCEPTION)
|
|
|
|
->setMessage(pht('Unhandled Exception: %s', $ex->getMessage()))
|
|
|
|
->save();
|
2011-05-04 23:09:42 -07:00
|
|
|
|
2013-05-17 10:00:49 -07:00
|
|
|
throw $ex;
|
2011-05-04 23:09:42 -07:00
|
|
|
}
|
|
|
|
|
2013-05-17 10:00:49 -07:00
|
|
|
return $this->setMessage('OK')->save();
|
2011-05-04 23:09:42 -07:00
|
|
|
}
|
|
|
|
|
2011-05-16 12:31:18 -07:00
|
|
|
public function getCleanTextBody() {
|
2013-10-14 12:29:41 -07:00
|
|
|
$body = $this->getRawTextBody();
|
2012-04-08 15:04:12 -07:00
|
|
|
$parser = new PhabricatorMetaMTAEmailBodyParser();
|
|
|
|
return $parser->stripTextBody($body);
|
2011-05-04 23:09:42 -07:00
|
|
|
}
|
|
|
|
|
2013-10-14 12:29:41 -07:00
|
|
|
public function parseBody() {
|
|
|
|
$body = $this->getRawTextBody();
|
|
|
|
$parser = new PhabricatorMetaMTAEmailBodyParser();
|
|
|
|
return $parser->parseBody($body);
|
|
|
|
}
|
|
|
|
|
2012-07-12 13:33:26 -07:00
|
|
|
public function getRawTextBody() {
|
|
|
|
return idx($this->bodies, 'text');
|
|
|
|
}
|
|
|
|
|
2011-07-04 09:45:42 -07:00
|
|
|
/**
|
|
|
|
* Strip an email address down to the actual user@domain.tld part if
|
|
|
|
* necessary, since sometimes it will have formatting like
|
|
|
|
* '"Abraham Lincoln" <alincoln@logcab.in>'.
|
|
|
|
*/
|
|
|
|
private function getRawEmailAddress($address) {
|
|
|
|
$matches = null;
|
|
|
|
$ok = preg_match('/<(.*)>/', $address, $matches);
|
|
|
|
if ($ok) {
|
|
|
|
$address = $matches[1];
|
|
|
|
}
|
|
|
|
return $address;
|
|
|
|
}
|
|
|
|
|
2012-08-28 14:09:37 -07:00
|
|
|
private function getRawEmailAddresses($addresses) {
|
|
|
|
$raw_addresses = array();
|
|
|
|
foreach (explode(',', $addresses) as $address) {
|
|
|
|
$raw_addresses[] = $this->getRawEmailAddress($address);
|
|
|
|
}
|
2012-11-08 12:21:50 -08:00
|
|
|
return array_filter($raw_addresses);
|
2012-08-28 14:09:37 -07:00
|
|
|
}
|
|
|
|
|
2013-05-13 16:32:19 -07:00
|
|
|
/**
|
|
|
|
* If Phabricator sent the mail, always drop it immediately. This prevents
|
|
|
|
* loops where, e.g., the public bug address is also a user email address
|
|
|
|
* and creating a bug sends them an email, which loops.
|
|
|
|
*/
|
|
|
|
private function dropMailFromPhabricator() {
|
|
|
|
if (!$this->getHeader('x-phabricator-sent-this-message')) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new PhabricatorMetaMTAReceivedMailProcessingException(
|
|
|
|
MetaMTAReceivedMailStatus::STATUS_FROM_PHABRICATOR,
|
When we fail to process mail, tell the user about it
Summary:
Ref T4371. Ref T4699. Fixes T3994.
Currently, we're very conservative about sending errors back to users. A concern I had about this was that mistakes could lead to email loops, massive amounts of email spam, etc. Because of this, I was pretty hesitant about replying to email with more email when I wrote this stuff.
However, this was a long time ago. We now have Message-ID deduplication, "X-Phabricator-Sent-This-Mail", generally better mail infrastructure, and rate limiting. Together, these mechanisms should reasonably prevent anything crazy (primarily, infinite email loops) from happening.
Thus:
- When we hit any processing error after receiving a mail, try to send the author a reply with details about what went wrong. These are limited to 6 per hour per address.
- Rewrite most of the errors to be more detailed and informative.
- Rewrite most of the errors in a user-facing voice ("You sent this mail..." instead of "This mail was sent..").
- Remove the redundant, less sophisticated code which does something similar in Differential.
Test Plan:
- Using `scripts/mail/mail_receiver.php`, artificially received a pile of mail.
- Hit a bunch of different errors.
- Saw reasonable error mail get sent to me.
- Saw other reasonable error mail get rate limited.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T3994, T4371, T4699
Differential Revision: https://secure.phabricator.com/D8692
2014-04-03 18:43:18 -07:00
|
|
|
pht(
|
|
|
|
"Ignoring email with 'X-Phabricator-Sent-This-Message' header to ".
|
|
|
|
"avoid loops."));
|
2013-05-13 16:32:19 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If this mail has the same message ID as some other mail, and isn't the
|
|
|
|
* first mail we we received with that message ID, we drop it as a duplicate.
|
|
|
|
*/
|
|
|
|
private function dropMailAlreadyReceived() {
|
|
|
|
$message_id_hash = $this->getMessageIDHash();
|
|
|
|
if (!$message_id_hash) {
|
|
|
|
// No message ID hash, so we can't detect duplicates. This should only
|
|
|
|
// happen with very old messages.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$messages = $this->loadAllWhere(
|
|
|
|
'messageIDHash = %s ORDER BY id ASC LIMIT 2',
|
|
|
|
$message_id_hash);
|
|
|
|
$messages_count = count($messages);
|
|
|
|
if ($messages_count <= 1) {
|
|
|
|
// If we only have one copy of this message, we're good to process it.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$first_message = reset($messages);
|
|
|
|
if ($first_message->getID() == $this->getID()) {
|
|
|
|
// If this is the first copy of the message, it is okay to process it.
|
|
|
|
// We may not have been able to to process it immediately when we received
|
|
|
|
// it, and could may have received several copies without processing any
|
|
|
|
// yet.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
When we fail to process mail, tell the user about it
Summary:
Ref T4371. Ref T4699. Fixes T3994.
Currently, we're very conservative about sending errors back to users. A concern I had about this was that mistakes could lead to email loops, massive amounts of email spam, etc. Because of this, I was pretty hesitant about replying to email with more email when I wrote this stuff.
However, this was a long time ago. We now have Message-ID deduplication, "X-Phabricator-Sent-This-Mail", generally better mail infrastructure, and rate limiting. Together, these mechanisms should reasonably prevent anything crazy (primarily, infinite email loops) from happening.
Thus:
- When we hit any processing error after receiving a mail, try to send the author a reply with details about what went wrong. These are limited to 6 per hour per address.
- Rewrite most of the errors to be more detailed and informative.
- Rewrite most of the errors in a user-facing voice ("You sent this mail..." instead of "This mail was sent..").
- Remove the redundant, less sophisticated code which does something similar in Differential.
Test Plan:
- Using `scripts/mail/mail_receiver.php`, artificially received a pile of mail.
- Hit a bunch of different errors.
- Saw reasonable error mail get sent to me.
- Saw other reasonable error mail get rate limited.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T3994, T4371, T4699
Differential Revision: https://secure.phabricator.com/D8692
2014-04-03 18:43:18 -07:00
|
|
|
$message = pht(
|
|
|
|
'Ignoring email with "Message-ID" hash "%s" that has been seen %d '.
|
2013-05-13 16:32:19 -07:00
|
|
|
'times, including this message.',
|
|
|
|
$message_id_hash,
|
|
|
|
$messages_count);
|
|
|
|
|
|
|
|
throw new PhabricatorMetaMTAReceivedMailProcessingException(
|
|
|
|
MetaMTAReceivedMailStatus::STATUS_DUPLICATE,
|
|
|
|
$message);
|
|
|
|
}
|
|
|
|
|
2013-05-14 10:57:41 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Load a concrete instance of the @{class:PhabricatorMailReceiver} which
|
|
|
|
* accepts this mail, if one exists.
|
|
|
|
*/
|
|
|
|
private function loadReceiver() {
|
|
|
|
$receivers = id(new PhutilSymbolLoader())
|
|
|
|
->setAncestorClass('PhabricatorMailReceiver')
|
|
|
|
->loadObjects();
|
|
|
|
|
|
|
|
$accept = array();
|
|
|
|
foreach ($receivers as $key => $receiver) {
|
|
|
|
if (!$receiver->isEnabled()) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ($receiver->canAcceptMail($this)) {
|
|
|
|
$accept[$key] = $receiver;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!$accept) {
|
|
|
|
throw new PhabricatorMetaMTAReceivedMailProcessingException(
|
|
|
|
MetaMTAReceivedMailStatus::STATUS_NO_RECEIVERS,
|
When we fail to process mail, tell the user about it
Summary:
Ref T4371. Ref T4699. Fixes T3994.
Currently, we're very conservative about sending errors back to users. A concern I had about this was that mistakes could lead to email loops, massive amounts of email spam, etc. Because of this, I was pretty hesitant about replying to email with more email when I wrote this stuff.
However, this was a long time ago. We now have Message-ID deduplication, "X-Phabricator-Sent-This-Mail", generally better mail infrastructure, and rate limiting. Together, these mechanisms should reasonably prevent anything crazy (primarily, infinite email loops) from happening.
Thus:
- When we hit any processing error after receiving a mail, try to send the author a reply with details about what went wrong. These are limited to 6 per hour per address.
- Rewrite most of the errors to be more detailed and informative.
- Rewrite most of the errors in a user-facing voice ("You sent this mail..." instead of "This mail was sent..").
- Remove the redundant, less sophisticated code which does something similar in Differential.
Test Plan:
- Using `scripts/mail/mail_receiver.php`, artificially received a pile of mail.
- Hit a bunch of different errors.
- Saw reasonable error mail get sent to me.
- Saw other reasonable error mail get rate limited.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T3994, T4371, T4699
Differential Revision: https://secure.phabricator.com/D8692
2014-04-03 18:43:18 -07:00
|
|
|
pht(
|
|
|
|
'Phabricator can not process this mail because no application '.
|
|
|
|
'knows how to handle it. Check that the address you sent it to is '.
|
|
|
|
'correct.'.
|
|
|
|
"\n\n".
|
|
|
|
'(No concrete, enabled subclass of PhabricatorMailReceiver can '.
|
|
|
|
'accept this mail.)'));
|
2013-05-14 10:57:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (count($accept) > 1) {
|
|
|
|
$names = implode(', ', array_keys($accept));
|
|
|
|
throw new PhabricatorMetaMTAReceivedMailProcessingException(
|
|
|
|
MetaMTAReceivedMailStatus::STATUS_ABUNDANT_RECEIVERS,
|
When we fail to process mail, tell the user about it
Summary:
Ref T4371. Ref T4699. Fixes T3994.
Currently, we're very conservative about sending errors back to users. A concern I had about this was that mistakes could lead to email loops, massive amounts of email spam, etc. Because of this, I was pretty hesitant about replying to email with more email when I wrote this stuff.
However, this was a long time ago. We now have Message-ID deduplication, "X-Phabricator-Sent-This-Mail", generally better mail infrastructure, and rate limiting. Together, these mechanisms should reasonably prevent anything crazy (primarily, infinite email loops) from happening.
Thus:
- When we hit any processing error after receiving a mail, try to send the author a reply with details about what went wrong. These are limited to 6 per hour per address.
- Rewrite most of the errors to be more detailed and informative.
- Rewrite most of the errors in a user-facing voice ("You sent this mail..." instead of "This mail was sent..").
- Remove the redundant, less sophisticated code which does something similar in Differential.
Test Plan:
- Using `scripts/mail/mail_receiver.php`, artificially received a pile of mail.
- Hit a bunch of different errors.
- Saw reasonable error mail get sent to me.
- Saw other reasonable error mail get rate limited.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T3994, T4371, T4699
Differential Revision: https://secure.phabricator.com/D8692
2014-04-03 18:43:18 -07:00
|
|
|
pht(
|
|
|
|
'Phabricator is not able to process this mail because more than '.
|
|
|
|
'one application is willing to accept it, creating ambiguity. '.
|
|
|
|
'Mail needs to be accepted by exactly one receiving application.'.
|
|
|
|
"\n\n".
|
|
|
|
'Accepting receivers: %s.',
|
|
|
|
$names));
|
2013-05-14 10:57:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return head($accept);
|
|
|
|
}
|
|
|
|
|
When we fail to process mail, tell the user about it
Summary:
Ref T4371. Ref T4699. Fixes T3994.
Currently, we're very conservative about sending errors back to users. A concern I had about this was that mistakes could lead to email loops, massive amounts of email spam, etc. Because of this, I was pretty hesitant about replying to email with more email when I wrote this stuff.
However, this was a long time ago. We now have Message-ID deduplication, "X-Phabricator-Sent-This-Mail", generally better mail infrastructure, and rate limiting. Together, these mechanisms should reasonably prevent anything crazy (primarily, infinite email loops) from happening.
Thus:
- When we hit any processing error after receiving a mail, try to send the author a reply with details about what went wrong. These are limited to 6 per hour per address.
- Rewrite most of the errors to be more detailed and informative.
- Rewrite most of the errors in a user-facing voice ("You sent this mail..." instead of "This mail was sent..").
- Remove the redundant, less sophisticated code which does something similar in Differential.
Test Plan:
- Using `scripts/mail/mail_receiver.php`, artificially received a pile of mail.
- Hit a bunch of different errors.
- Saw reasonable error mail get sent to me.
- Saw other reasonable error mail get rate limited.
Reviewers: btrahan
Reviewed By: btrahan
Subscribers: epriestley
Maniphest Tasks: T3994, T4371, T4699
Differential Revision: https://secure.phabricator.com/D8692
2014-04-03 18:43:18 -07:00
|
|
|
private function sendExceptionMail(Exception $ex) {
|
|
|
|
$from = $this->getHeader('from');
|
|
|
|
if (!strlen($from)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($ex instanceof PhabricatorMetaMTAReceivedMailProcessingException) {
|
|
|
|
$status_code = $ex->getStatusCode();
|
|
|
|
$status_name = MetaMTAReceivedMailStatus::getHumanReadableName(
|
|
|
|
$status_code);
|
|
|
|
|
|
|
|
$title = pht('Error Processing Mail (%s)', $status_name);
|
|
|
|
$description = $ex->getMessage();
|
|
|
|
} else {
|
|
|
|
$title = pht('Error Processing Mail (%s)', get_class($ex));
|
|
|
|
$description = pht('%s: %s', get_class($ex), $ex->getMessage());
|
|
|
|
}
|
|
|
|
|
|
|
|
$body = pht(<<<EOBODY
|
|
|
|
Your email to Phabricator was not processed, because an error occurred while
|
|
|
|
trying to handle it:
|
|
|
|
|
|
|
|
%s
|
|
|
|
|
|
|
|
-- Original Message Body -----------------------------------------------------
|
|
|
|
|
|
|
|
%s
|
|
|
|
|
|
|
|
EOBODY
|
|
|
|
,
|
|
|
|
wordwrap($description, 78),
|
|
|
|
$this->getRawTextBody());
|
|
|
|
|
|
|
|
$mail = id(new PhabricatorMetaMTAMail())
|
|
|
|
->setIsErrorEmail(true)
|
|
|
|
->setSubject($title)
|
|
|
|
->addRawTos(array($from))
|
|
|
|
->setBody($body)
|
|
|
|
->saveAndSend();
|
|
|
|
}
|
|
|
|
|
2011-05-04 23:09:42 -07:00
|
|
|
}
|