mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-13 00:01:03 +01:00
Remove all application-specific reply handler domains
Summary: Ref T7199. These were a bad idea which got copy-pasted a bunch. - There is zero reason to ever set these to different things. - Unsurprisingly, I don't know of any install which has them set to different things. Unless I've completely forgotten about it, this option was not motivated by some obscure business need, it was just a bad decision which didn't catch anyone's attention at the time. We partially remedied the mistake at some point by introducing `metamta.reply-handler-domain`, which works as a default for all applications, but never cleaned this mess up. Test Plan: Sent some mail from applications, verified it picked up appropraite reply handler domains. Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T7199 Differential Revision: https://secure.phabricator.com/D12231
This commit is contained in:
parent
0d99c84bd7
commit
bad645f1ec
16 changed files with 24 additions and 106 deletions
|
@ -17,11 +17,6 @@ final class PhabricatorAuditReplyHandler extends PhabricatorMailReplyHandler {
|
||||||
return $this->getDefaultPublicReplyHandlerEmailAddress('C');
|
return $this->getDefaultPublicReplyHandlerEmailAddress('C');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
|
||||||
return $this->getCustomReplyHandlerDomainIfExists(
|
|
||||||
'metamta.diffusion.reply-handler-domain');
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
||||||
$commit = $this->getMailReceiver();
|
$commit = $this->getMailReceiver();
|
||||||
$actor = $this->getActor();
|
$actor = $this->getActor();
|
||||||
|
|
|
@ -159,6 +159,11 @@ final class PhabricatorExtraConfigSetupCheck extends PhabricatorSetupCheck {
|
||||||
'option "%s". Use that option to configure which fields are shown.',
|
'option "%s". Use that option to configure which fields are shown.',
|
||||||
'differential.fields');
|
'differential.fields');
|
||||||
|
|
||||||
|
$reply_domain_reason = pht(
|
||||||
|
'Individual application reply handler domains have been removed. '.
|
||||||
|
'Configure a reply domain with "%s".',
|
||||||
|
'metamta.reply-handler-domain');
|
||||||
|
|
||||||
$ancient_config += array(
|
$ancient_config += array(
|
||||||
'phid.external-loaders' =>
|
'phid.external-loaders' =>
|
||||||
pht(
|
pht(
|
||||||
|
@ -222,6 +227,12 @@ final class PhabricatorExtraConfigSetupCheck extends PhabricatorSetupCheck {
|
||||||
'`security.outbound-blacklist`.'),
|
'`security.outbound-blacklist`.'),
|
||||||
'metamta.reply.show-hints' => pht(
|
'metamta.reply.show-hints' => pht(
|
||||||
'Phabricator no longer shows reply hints in mail.'),
|
'Phabricator no longer shows reply hints in mail.'),
|
||||||
|
|
||||||
|
'metamta.differential.reply-handler-domain' => $reply_domain_reason,
|
||||||
|
'metamta.diffusion.reply-handler-domain' => $reply_domain_reason,
|
||||||
|
'metamta.macro.reply-handler-domain' => $reply_domain_reason,
|
||||||
|
'metamta.maniphest.reply-handler-domain' => $reply_domain_reason,
|
||||||
|
'metamta.pholio.reply-handler-domain' => $reply_domain_reason,
|
||||||
);
|
);
|
||||||
|
|
||||||
return $ancient_config;
|
return $ancient_config;
|
||||||
|
|
|
@ -245,9 +245,7 @@ EODOC
|
||||||
'string',
|
'string',
|
||||||
null)
|
null)
|
||||||
->setLocked(true)
|
->setLocked(true)
|
||||||
->setDescription(pht(
|
->setDescription(pht('Domain used for reply email addresses.'))
|
||||||
'Domain used for reply email addresses. Some applications can '.
|
|
||||||
'override this configuration with a different domain.'))
|
|
||||||
->addExample('phabricator.example.com', ''),
|
->addExample('phabricator.example.com', ''),
|
||||||
$this->newOption('metamta.herald.show-hints', 'bool', true)
|
$this->newOption('metamta.herald.show-hints', 'bool', true)
|
||||||
->setBoolOptions(
|
->setBoolOptions(
|
||||||
|
|
|
@ -244,13 +244,6 @@ final class PhabricatorDifferentialConfigOptions
|
||||||
pht(
|
pht(
|
||||||
"Similar to `differential.days-fresh` but marks stale revisions. ".
|
"Similar to `differential.days-fresh` but marks stale revisions. ".
|
||||||
"If the revision is even older than it is when marked as 'old'.")),
|
"If the revision is even older than it is when marked as 'old'.")),
|
||||||
$this->newOption(
|
|
||||||
'metamta.differential.reply-handler-domain',
|
|
||||||
'string',
|
|
||||||
null)
|
|
||||||
->setLocked(true)
|
|
||||||
->setDescription(
|
|
||||||
pht('Inbound email domain for Differential replies.')),
|
|
||||||
$this->newOption(
|
$this->newOption(
|
||||||
'metamta.differential.reply-handler',
|
'metamta.differential.reply-handler',
|
||||||
'class',
|
'class',
|
||||||
|
|
|
@ -17,11 +17,6 @@ final class DifferentialReplyHandler extends PhabricatorMailReplyHandler {
|
||||||
return $this->getDefaultPublicReplyHandlerEmailAddress('D');
|
return $this->getDefaultPublicReplyHandlerEmailAddress('D');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
|
||||||
return $this->getCustomReplyHandlerDomainIfExists(
|
|
||||||
'metamta.differential.reply-handler-domain');
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getSupportedCommands() {
|
public function getSupportedCommands() {
|
||||||
$actions = array(
|
$actions = array(
|
||||||
DifferentialAction::ACTION_COMMENT,
|
DifferentialAction::ACTION_COMMENT,
|
||||||
|
|
|
@ -26,15 +26,6 @@ final class PhabricatorDiffusionConfigOptions
|
||||||
'string',
|
'string',
|
||||||
'[Diffusion]')
|
'[Diffusion]')
|
||||||
->setDescription(pht('Subject prefix for Diffusion mail.')),
|
->setDescription(pht('Subject prefix for Diffusion mail.')),
|
||||||
$this->newOption(
|
|
||||||
'metamta.diffusion.reply-handler-domain',
|
|
||||||
'string',
|
|
||||||
null)
|
|
||||||
->setLocked(true)
|
|
||||||
->setDescription(
|
|
||||||
pht(
|
|
||||||
'See {{metamta.maniphest.reply-handler}}. This does the same '.
|
|
||||||
'thing, but affects Diffusion.')),
|
|
||||||
$this->newOption(
|
$this->newOption(
|
||||||
'metamta.diffusion.reply-handler',
|
'metamta.diffusion.reply-handler',
|
||||||
'class',
|
'class',
|
||||||
|
|
|
@ -21,10 +21,6 @@ final class PhabricatorMacroConfigOptions
|
||||||
|
|
||||||
public function getOptions() {
|
public function getOptions() {
|
||||||
return array(
|
return array(
|
||||||
$this->newOption('metamta.macro.reply-handler-domain', 'string', null)
|
|
||||||
->setLocked(true)
|
|
||||||
->setDescription(pht(
|
|
||||||
'As {{metamta.maniphest.reply-handler-domain}}, but affects Macro.')),
|
|
||||||
$this->newOption('metamta.macro.subject-prefix', 'string', '[Macro]')
|
$this->newOption('metamta.macro.subject-prefix', 'string', '[Macro]')
|
||||||
->setDescription(pht('Subject prefix for Macro email.')),
|
->setDescription(pht('Subject prefix for Macro email.')),
|
||||||
);
|
);
|
||||||
|
|
|
@ -17,11 +17,6 @@ final class PhabricatorMacroReplyHandler extends PhabricatorMailReplyHandler {
|
||||||
return $this->getDefaultPublicReplyHandlerEmailAddress('MCRO');
|
return $this->getDefaultPublicReplyHandlerEmailAddress('MCRO');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
|
||||||
return $this->getCustomReplyHandlerDomainIfExists(
|
|
||||||
'metamta.macro.reply-handler-domain');
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
||||||
// TODO: Implement this.
|
// TODO: Implement this.
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -272,27 +272,6 @@ EOTEXT
|
||||||
'review and adjust available priorities by using the '.
|
'review and adjust available priorities by using the '.
|
||||||
'{{maniphest.priorities}} configuration option. The default value '.
|
'{{maniphest.priorities}} configuration option. The default value '.
|
||||||
'(`90`) corresponds to the default "Needs Triage" priority.')),
|
'(`90`) corresponds to the default "Needs Triage" priority.')),
|
||||||
$this->newOption(
|
|
||||||
'metamta.maniphest.reply-handler-domain',
|
|
||||||
'string',
|
|
||||||
null)
|
|
||||||
->setLocked(true)
|
|
||||||
->setSummary(pht('Enable replying to tasks via email.'))
|
|
||||||
->setDescription(
|
|
||||||
pht(
|
|
||||||
'You can configure a reply handler domain so that email sent from '.
|
|
||||||
'Maniphest will have a special "Reply To" address like '.
|
|
||||||
'"T123+82+af19f@example.com" that allows recipients to reply by '.
|
|
||||||
'email and interact with tasks. For instructions on configurating '.
|
|
||||||
'reply handlers, see the article "Configuring Inbound Email" in '.
|
|
||||||
'the Phabricator documentation. By default, this is set to `null` '.
|
|
||||||
'and Phabricator will use a generic `noreply@` address or the '.
|
|
||||||
'address of the acting user instead of a special reply handler '.
|
|
||||||
'address (see `metamta.default-address`). If you set a domain '.
|
|
||||||
'here, Phabricator will begin generating private reply handler '.
|
|
||||||
'addresses. See also `metamta.maniphest.reply-handler` to further '.
|
|
||||||
'configure behavior. This key should be set to the domain part '.
|
|
||||||
'after the @, like "example.com".')),
|
|
||||||
$this->newOption(
|
$this->newOption(
|
||||||
'metamta.maniphest.reply-handler',
|
'metamta.maniphest.reply-handler',
|
||||||
'class',
|
'class',
|
||||||
|
|
|
@ -17,11 +17,6 @@ final class ManiphestReplyHandler extends PhabricatorMailReplyHandler {
|
||||||
return $this->getDefaultPublicReplyHandlerEmailAddress('T');
|
return $this->getDefaultPublicReplyHandlerEmailAddress('T');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
|
||||||
return $this->getCustomReplyHandlerDomainIfExists(
|
|
||||||
'metamta.maniphest.reply-handler-domain');
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
||||||
// NOTE: We'll drop in here on both the "reply to a task" and "create a
|
// NOTE: We'll drop in here on both the "reply to a task" and "create a
|
||||||
// new task" workflows! Make sure you test both if you make changes!
|
// new task" workflows! Make sure you test both if you make changes!
|
||||||
|
|
|
@ -48,19 +48,9 @@ abstract class PhabricatorMailReplyHandler {
|
||||||
abstract public function validateMailReceiver($mail_receiver);
|
abstract public function validateMailReceiver($mail_receiver);
|
||||||
abstract public function getPrivateReplyHandlerEmailAddress(
|
abstract public function getPrivateReplyHandlerEmailAddress(
|
||||||
PhabricatorObjectHandle $handle);
|
PhabricatorObjectHandle $handle);
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
public function getReplyHandlerDomain() {
|
||||||
return $this->getDefaultReplyHandlerDomain();
|
return PhabricatorEnv::getEnvConfig('metamta.reply-handler-domain');
|
||||||
}
|
|
||||||
protected function getCustomReplyHandlerDomainIfExists($config_key) {
|
|
||||||
$domain = PhabricatorEnv::getEnvConfig($config_key);
|
|
||||||
if ($domain) {
|
|
||||||
return $domain;
|
|
||||||
}
|
|
||||||
return $this->getDefaultReplyHandlerDomain();
|
|
||||||
}
|
|
||||||
private function getDefaultReplyHandlerDomain() {
|
|
||||||
return PhabricatorEnv::getEnvConfig(
|
|
||||||
'metamta.reply-handler-domain');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract protected function receiveEmail(
|
abstract protected function receiveEmail(
|
||||||
|
@ -110,9 +100,11 @@ abstract class PhabricatorMailReplyHandler {
|
||||||
if (!PhabricatorEnv::getEnvConfig('metamta.public-replies')) {
|
if (!PhabricatorEnv::getEnvConfig('metamta.public-replies')) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$this->getReplyHandlerDomain()) {
|
if (!$this->getReplyHandlerDomain()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (bool)$this->getPublicReplyHandlerEmailAddress();
|
return (bool)$this->getPublicReplyHandlerEmailAddress();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,10 +16,6 @@ final class OwnersPackageReplyHandler extends PhabricatorMailReplyHandler {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,12 +21,6 @@ final class PhabricatorPholioConfigOptions
|
||||||
|
|
||||||
public function getOptions() {
|
public function getOptions() {
|
||||||
return array(
|
return array(
|
||||||
$this->newOption('metamta.pholio.reply-handler-domain', 'string', null)
|
|
||||||
->setLocked(true)
|
|
||||||
->setDescription(
|
|
||||||
pht(
|
|
||||||
'Like {{metamta.maniphest.reply-handler-domain}}, but affects '.
|
|
||||||
'Pholio.')),
|
|
||||||
$this->newOption('metamta.pholio.subject-prefix', 'string', '[Pholio]')
|
$this->newOption('metamta.pholio.subject-prefix', 'string', '[Pholio]')
|
||||||
->setDescription(pht('Subject prefix for Pholio email.')),
|
->setDescription(pht('Subject prefix for Pholio email.')),
|
||||||
);
|
);
|
||||||
|
|
|
@ -17,11 +17,6 @@ final class PholioReplyHandler extends PhabricatorMailReplyHandler {
|
||||||
return $this->getDefaultPublicReplyHandlerEmailAddress('M');
|
return $this->getDefaultPublicReplyHandlerEmailAddress('M');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
|
||||||
return $this->getCustomReplyHandlerDomainIfExists(
|
|
||||||
'metamta.pholio.reply-handler-domain');
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
||||||
// TODO: Implement this.
|
// TODO: Implement this.
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -12,10 +12,6 @@ final class PhabricatorRepositoryPushReplyHandler
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getReplyHandlerDomain() {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -135,24 +135,21 @@ To use SendGrid, you need a SendGrid account with access to the "Parse API" for
|
||||||
inbound email. Provided you have such an account, configure it like this:
|
inbound email. Provided you have such an account, configure it like this:
|
||||||
|
|
||||||
- Configure an MX record according to SendGrid's instructions, i.e. add
|
- Configure an MX record according to SendGrid's instructions, i.e. add
|
||||||
##phabricator.example.com MX 10 mx.sendgrid.net.## or similar.
|
`phabricator.example.com MX 10 mx.sendgrid.net.` or similar.
|
||||||
- Go to the "Parse Incoming Emails" page on SendGrid
|
- Go to the "Parse Incoming Emails" page on SendGrid
|
||||||
(<http://sendgrid.com/developer/reply>) and add the domain as the
|
(<http://sendgrid.com/developer/reply>) and add the domain as the
|
||||||
"Hostname".
|
"Hostname".
|
||||||
- Add the URL ##https://phabricator.example.com/mail/sendgrid/## as the "Url",
|
- Add the URL `https://phabricator.example.com/mail/sendgrid/` as the "Url",
|
||||||
using your domain (and HTTP instead of HTTPS if you are not configured with
|
using your domain (and HTTP instead of HTTPS if you are not configured with
|
||||||
SSL).
|
SSL).
|
||||||
- If you get an error that the hostname "can't be located or verified", it
|
- If you get an error that the hostname "can't be located or verified", it
|
||||||
means your MX record is either incorrectly configured or hasn't propagated
|
means your MX record is either incorrectly configured or hasn't propagated
|
||||||
yet.
|
yet.
|
||||||
- Set ##metamta.maniphest.reply-handler-domain## and/or
|
- Set `metamta.reply-handler-domain` to `phabricator.example.com`"
|
||||||
##metamta.differential.reply-handler-domain## to
|
(whatever you configured the MX record for).
|
||||||
"##phabricator.example.com##" (whatever you configured the MX record for),
|
|
||||||
depending on whether you want to support email replies for Maniphest,
|
|
||||||
Differential, or both.
|
|
||||||
|
|
||||||
That's it! If everything is working properly you should be able to send email
|
That's it! If everything is working properly you should be able to send email
|
||||||
to ##anything@phabricator.example.com## and it should appear in
|
to `anything@phabricator.example.com` and it should appear in
|
||||||
`bin/mail list-inbound` within a few seconds.
|
`bin/mail list-inbound` within a few seconds.
|
||||||
|
|
||||||
= Local MTA: Installing Mailparse =
|
= Local MTA: Installing Mailparse =
|
||||||
|
@ -211,12 +208,12 @@ this script into `/etc/smrsh/`:
|
||||||
|
|
||||||
sudo ln -s /path/to/phabricator/scripts/mail/mail_handler.php /etc/smrsh/
|
sudo ln -s /path/to/phabricator/scripts/mail/mail_handler.php /etc/smrsh/
|
||||||
|
|
||||||
Finally, edit ##/etc/mail/virtusertable## and add an entry like this:
|
Finally, edit `/etc/mail/virtusertable` and add an entry like this:
|
||||||
|
|
||||||
@yourdomain.com phabricator@localhost
|
@yourdomain.com phabricator@localhost
|
||||||
|
|
||||||
That will forward all mail to @yourdomain.com to the Phabricator processing
|
That will forward all mail to @yourdomain.com to the Phabricator processing
|
||||||
script. Run ##sudo /etc/mail/make## or similar and then restart sendmail with
|
script. Run `sudo /etc/mail/make` or similar and then restart sendmail with
|
||||||
`sudo /etc/init.d/sendmail restart`.
|
`sudo /etc/init.d/sendmail restart`.
|
||||||
|
|
||||||
= Local MTA: Configuring Lamson =
|
= Local MTA: Configuring Lamson =
|
||||||
|
@ -232,7 +229,7 @@ To get started, follow the provided instructions
|
||||||
(<http://lamsonproject.org/docs/getting_started.html>) to set up an instance.
|
(<http://lamsonproject.org/docs/getting_started.html>) to set up an instance.
|
||||||
One likely deployment issue is that binding to port 25 requires root
|
One likely deployment issue is that binding to port 25 requires root
|
||||||
privileges. Lamson is capable of starting as root then dropping privileges, but
|
privileges. Lamson is capable of starting as root then dropping privileges, but
|
||||||
you must supply ##-uid## and ##-gid## arguments to do so, as demonstrated by
|
you must supply `-uid` and `-gid` arguments to do so, as demonstrated by
|
||||||
Step 8 in Lamson's deployment tutorial (located here:
|
Step 8 in Lamson's deployment tutorial (located here:
|
||||||
<http://lamsonproject.org/docs/deploying_oneshotblog.html>).
|
<http://lamsonproject.org/docs/deploying_oneshotblog.html>).
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue