mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-10 00:42:41 +01:00
I think this improves email a good deal, although it's hard to really test it
since Exchange has been down for like 30 minutes now. Push & Pray! Summary: Test Plan: Reviewers: CC:
This commit is contained in:
parent
e3a91902b7
commit
616c22eae2
4 changed files with 85 additions and 20 deletions
|
@ -35,22 +35,6 @@ return array(
|
||||||
// be 50x50px.
|
// be 50x50px.
|
||||||
'user.default-profile-image-phid' => 'PHID-FILE-f57aaefce707fc4060ef',
|
'user.default-profile-image-phid' => 'PHID-FILE-f57aaefce707fc4060ef',
|
||||||
|
|
||||||
// When email is sent, try to hand it off to the MTA immediately. The only
|
|
||||||
// reason to disable this is if your MTA infrastructure is completely
|
|
||||||
// terrible. If you disable this option, you must run the 'metamta_mta.php'
|
|
||||||
// daemon or mail won't be handed off to the MTA.
|
|
||||||
'metamta.send-immediately' => true,
|
|
||||||
|
|
||||||
// "Reply-To" email address to use for no-reply emails.
|
|
||||||
'metamta.noreply' => 'noreply@example.com',
|
|
||||||
|
|
||||||
'metamta.mail-adapter' =>
|
|
||||||
'PhabricatorMailImplementationPHPMailerLiteAdapter',
|
|
||||||
|
|
||||||
'amazon-ses.access-key' => null,
|
|
||||||
'amazon-ses.secret-key' => null,
|
|
||||||
|
|
||||||
|
|
||||||
// -- Access Control -------------------------------------------------------- //
|
// -- Access Control -------------------------------------------------------- //
|
||||||
|
|
||||||
// Phabricator users have one of three access levels: "anyone", "verified",
|
// Phabricator users have one of three access levels: "anyone", "verified",
|
||||||
|
@ -121,6 +105,69 @@ return array(
|
||||||
'mysql.host' => 'localhost',
|
'mysql.host' => 'localhost',
|
||||||
|
|
||||||
|
|
||||||
|
// -- Email ----------------------------------------------------------------- //
|
||||||
|
|
||||||
|
// Some Phabricator tools send email notifications, e.g. when Differential
|
||||||
|
// revisions are updated or Maniphest tasks are changed. These options allow
|
||||||
|
// you to configure how email is delivered.
|
||||||
|
|
||||||
|
// You can test your mail setup by going to "MetaMTA" in the web interface,
|
||||||
|
// clicking "Send New Message", and then composing a message.
|
||||||
|
|
||||||
|
// Default address to send mail "From".
|
||||||
|
'metamta.default-address' => 'noreply@example.com',
|
||||||
|
|
||||||
|
// When a user takes an action which generates an email notification (like
|
||||||
|
// commenting on a Differential revision), Phabricator can either send that
|
||||||
|
// mail "From" the user's email address (like "alincoln@logcabin.com") or
|
||||||
|
// "From" the 'metamta.default-address' address. The user experience is
|
||||||
|
// generally better if Phabricator uses the user's real address as the "From"
|
||||||
|
// since the messages are easier to organize when they appear in mail clients,
|
||||||
|
// but this will only work if the server is authorized to send email on behalf
|
||||||
|
// of the "From" domain. Practically, this means:
|
||||||
|
// - If you are doing an install for Example Corp and all the users will
|
||||||
|
// have corporate @corp.example.com addresses and any hosts Phabricator
|
||||||
|
// is running on are authorized to send email from corp.example.com,
|
||||||
|
// you can enable this to make the user experience a little better.
|
||||||
|
// - If you are doing an install for an open source project and your
|
||||||
|
// users will be registering via Facebook and using personal email
|
||||||
|
// addresses, you MUST NOT enable this or virtually all of your outgoing
|
||||||
|
// email will vanish into SFP blackholes.
|
||||||
|
// - If your install is anything else, you're much safer leaving this
|
||||||
|
// off since the risk in turning it on is that your outgoing mail will
|
||||||
|
// mostly never arrive.
|
||||||
|
'metamta.can-send-as-user' => false,
|
||||||
|
|
||||||
|
// Adapter class to use to transmit mail to the MTA. The default uses
|
||||||
|
// PHPMailerLite, which will invoke PHP's mail() function. This is appropriate
|
||||||
|
// if mail() actually works on your host, but if you haven't configured mail
|
||||||
|
// it may not be so great. You can also use Amazon SES, by changing this to
|
||||||
|
// 'PhabricatorMailImplementationAmazonSESAdapter', signing up for SES, and
|
||||||
|
// filling in your 'amazon-ses.access-key' and 'amazon-ses.secret-key' below.
|
||||||
|
'metamta.mail-adapter' =>
|
||||||
|
'PhabricatorMailImplementationPHPMailerLiteAdapter',
|
||||||
|
|
||||||
|
// When email is sent, try to hand it off to the MTA immediately. This may
|
||||||
|
// be worth disabling if your MTA infrastructure is slow or unreliable. If you
|
||||||
|
// disable this option, you must run the 'metamta_mta.php' daemon or mail
|
||||||
|
// won't be handed off to the MTA. If you're using Amazon SES it can be a
|
||||||
|
// little slugish sometimes so it may be worth disabling this and moving to
|
||||||
|
// the daemon after you've got your install up and running. If you have a
|
||||||
|
// properly configured local MTA it should not be necessary to disable this.
|
||||||
|
'metamta.send-immediately' => true,
|
||||||
|
|
||||||
|
// If you're using Amazon SES to send email, provide your AWS access key
|
||||||
|
// and AWS secret key here. To set up Amazon SES with Phabricator, you need
|
||||||
|
// to:
|
||||||
|
// - Make sure 'metamta.mail-adapter' is set to:
|
||||||
|
// "PhabricatorMailImplementationAmazonSESAdapter"
|
||||||
|
// - Make sure 'metamta.can-send-as-user' is false.
|
||||||
|
// - Make sure 'metamta.default-address' is configured to something sensible.
|
||||||
|
// - Make sure 'metamta.default-address' is a validated SES "From" address.
|
||||||
|
'amazon-ses.access-key' => null,
|
||||||
|
'amazon-ses.secret-key' => null,
|
||||||
|
|
||||||
|
|
||||||
// -- Facebook ------------------------------------------------------------ //
|
// -- Facebook ------------------------------------------------------------ //
|
||||||
|
|
||||||
// Can users use Facebook credentials to login to Phabricator?
|
// Can users use Facebook credentials to login to Phabricator?
|
||||||
|
|
|
@ -69,7 +69,6 @@ class PhabricatorEmailLoginController extends PhabricatorAuthController {
|
||||||
array(
|
array(
|
||||||
$target_user->getPHID(),
|
$target_user->getPHID(),
|
||||||
));
|
));
|
||||||
$mail->setReplyTo(PhabricatorEnv::getEnvConfig('metamta.noreply'));
|
|
||||||
$mail->setBody(
|
$mail->setBody(
|
||||||
"blah blah blah ".
|
"blah blah blah ".
|
||||||
PhabricatorEnv::getURI('/login/etoken/'.$etoken.'/').'?email='.phutil_escape_uri($target_user->getEmail()));
|
PhabricatorEnv::getURI('/login/etoken/'.$etoken.'/').'?email='.phutil_escape_uri($target_user->getEmail()));
|
||||||
|
|
|
@ -73,11 +73,16 @@ abstract class DifferentialMail {
|
||||||
|
|
||||||
$mail = new PhabricatorMetaMTAMail();
|
$mail = new PhabricatorMetaMTAMail();
|
||||||
$handle = $this->getActorHandle();
|
$handle = $this->getActorHandle();
|
||||||
|
$reply = $this->getReplyHandlerEmailAddress();
|
||||||
if ($handle) {
|
if ($handle) {
|
||||||
$mail->setFrom($handle->getPHID());
|
$mail->setFrom($handle->getPHID());
|
||||||
$mail->setReplyTo($this->getReplyHandlerEmailAddress());
|
if ($reply) {
|
||||||
|
$mail->setReplyTo($this->getReplyHandlerEmailAddress());
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
$mail->setFrom($this->getReplyHandlerEmailAddress());
|
if ($reply) {
|
||||||
|
$mail->setFrom($this->getReplyHandlerEmailAddress());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$mail
|
$mail
|
||||||
|
@ -144,6 +149,7 @@ EOTEXT;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getReplyHandlerEmailAddress() {
|
protected function getReplyHandlerEmailAddress() {
|
||||||
|
return null;
|
||||||
// TODO
|
// TODO
|
||||||
$phid = $this->getRevision()->getPHID();
|
$phid = $this->getRevision()->getPHID();
|
||||||
$server = 'todo.example.com';
|
$server = 'todo.example.com';
|
||||||
|
|
|
@ -167,7 +167,20 @@ class PhabricatorMetaMTAMail extends PhabricatorMetaMTADAO {
|
||||||
$handles = id(new PhabricatorObjectHandleData($phids))
|
$handles = id(new PhabricatorObjectHandleData($phids))
|
||||||
->loadHandles();
|
->loadHandles();
|
||||||
|
|
||||||
foreach ($this->parameters as $key => $value) {
|
$params = $this->parameters;
|
||||||
|
$default = PhabricatorEnv::getEnvConfig('metamta.default-address');
|
||||||
|
if (empty($params['from'])) {
|
||||||
|
$mailer->setFrom($default);
|
||||||
|
} else if (!PhabricatorEnv::getEnvConfig('metamta.can-send-as-user')) {
|
||||||
|
$from = $params['from'];
|
||||||
|
if (empty($params['reply-to'])) {
|
||||||
|
$params['reply-to'] = $handles[$from]->getEmail();
|
||||||
|
}
|
||||||
|
$mailer->setFrom($default);
|
||||||
|
unset($params['from']);
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($params as $key => $value) {
|
||||||
switch ($key) {
|
switch ($key) {
|
||||||
case 'from':
|
case 'from':
|
||||||
$mailer->setFrom($handles[$value]->getEmail());
|
$mailer->setFrom($handles[$value]->getEmail());
|
||||||
|
|
Loading…
Reference in a new issue