mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 23:31:03 +01:00
Make HTML email a little easier to debug
Summary: Ref T992. - Format text/HTML bodies explicitly in `bin/mail show-outbound`. - Provide `bin/mail show-outbound --dump-html` so you can do something like `bin/mail show-outbound --dump-html > dump.html; open dump.html` to get a browser preview somewhat easily. Test Plan: Ran `bin/mail show-outbound` with and without `--dump-html` flag. Reviewers: talshiri, btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T992 Differential Revision: https://secure.phabricator.com/D10272
This commit is contained in:
parent
eb3ed9bbc9
commit
8403812e15
2 changed files with 43 additions and 2 deletions
|
@ -17,6 +17,12 @@ final class PhabricatorMailManagementShowOutboundWorkflow
|
||||||
'help' => 'Show details about outbound mail with given ID.',
|
'help' => 'Show details about outbound mail with given ID.',
|
||||||
'repeat' => true,
|
'repeat' => true,
|
||||||
),
|
),
|
||||||
|
array(
|
||||||
|
'name' => 'dump-html',
|
||||||
|
'help' => pht(
|
||||||
|
'Dump the HTML body of the mail. You can redirect it to a '.
|
||||||
|
'file and then open it in a browser.'),
|
||||||
|
),
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,6 +51,20 @@ final class PhabricatorMailManagementShowOutboundWorkflow
|
||||||
|
|
||||||
$last_key = last_key($messages);
|
$last_key = last_key($messages);
|
||||||
foreach ($messages as $message_key => $message) {
|
foreach ($messages as $message_key => $message) {
|
||||||
|
if ($args->getArg('dump-html')) {
|
||||||
|
$html_body = $message->getHTMLBody();
|
||||||
|
if (strlen($html_body)) {
|
||||||
|
$template =
|
||||||
|
"<!doctype html><html><body>{$html_body}</body></html>";
|
||||||
|
$console->writeOut("%s\n", $html_body);
|
||||||
|
} else {
|
||||||
|
$console->writeErr(
|
||||||
|
"%s\n",
|
||||||
|
pht('(This message has no HTML body.)'));
|
||||||
|
}
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
$info = array();
|
$info = array();
|
||||||
|
|
||||||
$info[] = pht('PROPERTIES');
|
$info[] = pht('PROPERTIES');
|
||||||
|
@ -61,6 +81,10 @@ final class PhabricatorMailManagementShowOutboundWorkflow
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($key == 'html-body') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if ($key == 'headers') {
|
if ($key == 'headers') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -110,8 +134,21 @@ final class PhabricatorMailManagementShowOutboundWorkflow
|
||||||
}
|
}
|
||||||
|
|
||||||
$info[] = null;
|
$info[] = null;
|
||||||
$info[] = pht('BODY');
|
$info[] = pht('TEXT BODY');
|
||||||
|
if (strlen($message->getBody())) {
|
||||||
$info[] = $message->getBody();
|
$info[] = $message->getBody();
|
||||||
|
} else {
|
||||||
|
$info[] = pht('(This message has no text body.)');
|
||||||
|
}
|
||||||
|
|
||||||
|
$info[] = null;
|
||||||
|
$info[] = pht('HTML BODY');
|
||||||
|
if (strlen($message->getHTMLBody())) {
|
||||||
|
$info[] = $message->getHTMLBody();
|
||||||
|
$info[] = null;
|
||||||
|
} else {
|
||||||
|
$info[] = pht('(This message has no HTML body.)');
|
||||||
|
}
|
||||||
|
|
||||||
$console->writeOut('%s', implode("\n", $info));
|
$console->writeOut('%s', implode("\n", $info));
|
||||||
|
|
||||||
|
|
|
@ -221,6 +221,10 @@ final class PhabricatorMetaMTAMail extends PhabricatorMetaMTADAO {
|
||||||
return $this->getParam('body');
|
return $this->getParam('body');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getHTMLBody() {
|
||||||
|
return $this->getParam('html-body');
|
||||||
|
}
|
||||||
|
|
||||||
public function setIsErrorEmail($is_error) {
|
public function setIsErrorEmail($is_error) {
|
||||||
$this->setParam('is-error', $is_error);
|
$this->setParam('is-error', $is_error);
|
||||||
return $this;
|
return $this;
|
||||||
|
|
Loading…
Reference in a new issue