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

Provide context objects for remarkup mail rendering, fixing Phriction relative URIs in initial email

Summary:
Fixes T10969. Ref T13077. When you create a Phriction document with a relative link (`[[ ./path/to/page ]]`) the initial email currently points to the wrong place.

This is because the context object (the page) isn't passed to the markup engine. Without this context, the relative link is rendered as though it appeared somewhere else (like a task or revision) where relative links don't make sense.

Test Plan: Created a new Phriction document with a relative link to `[[ ./porcupine_facts/starmap ]]`, saw a usable link in the resulting email.

Maniphest Tasks: T13077, T10969

Differential Revision: https://secure.phabricator.com/D19105
This commit is contained in:
epriestley 2018-02-16 04:58:46 -08:00
parent f713e1dfc1
commit bfdc9411f7
3 changed files with 63 additions and 22 deletions

View file

@ -13,6 +13,7 @@ final class PhabricatorMetaMTAMailBody extends Phobject {
private $attachments = array(); private $attachments = array();
private $viewer; private $viewer;
private $contextObject;
public function getViewer() { public function getViewer() {
return $this->viewer; return $this->viewer;
@ -23,6 +24,16 @@ final class PhabricatorMetaMTAMailBody extends Phobject {
return $this; return $this;
} }
public function setContextObject($context_object) {
$this->contextObject = $context_object;
return $this;
}
public function getContextObject() {
return $this->contextObject;
}
/* -( Composition )-------------------------------------------------------- */ /* -( Composition )-------------------------------------------------------- */
@ -45,9 +56,9 @@ final class PhabricatorMetaMTAMailBody extends Phobject {
public function addRemarkupSection($header, $text) { public function addRemarkupSection($header, $text) {
try { try {
$engine = PhabricatorMarkupEngine::newMarkupEngine(array()); $engine = $this->newMarkupEngine()
$engine->setConfig('viewer', $this->getViewer()); ->setMode(PhutilRemarkupEngine::MODE_TEXT);
$engine->setMode(PhutilRemarkupEngine::MODE_TEXT);
$styled_text = $engine->markupText($text); $styled_text = $engine->markupText($text);
$this->addPlaintextSection($header, $styled_text); $this->addPlaintextSection($header, $styled_text);
} catch (Exception $ex) { } catch (Exception $ex) {
@ -56,12 +67,9 @@ final class PhabricatorMetaMTAMailBody extends Phobject {
} }
try { try {
$mail_engine = PhabricatorMarkupEngine::newMarkupEngine(array()); $mail_engine = $this->newMarkupEngine()
$mail_engine->setConfig('viewer', $this->getViewer()); ->setMode(PhutilRemarkupEngine::MODE_HTML_MAIL);
$mail_engine->setMode(PhutilRemarkupEngine::MODE_HTML_MAIL);
$mail_engine->setConfig(
'uri.base',
PhabricatorEnv::getProductionURI('/'));
$html = $mail_engine->markupText($text); $html = $mail_engine->markupText($text);
$this->addHTMLSection($header, $html); $this->addHTMLSection($header, $html);
} catch (Exception $ex) { } catch (Exception $ex) {
@ -215,4 +223,19 @@ final class PhabricatorMetaMTAMailBody extends Phobject {
private function indent($text) { private function indent($text) {
return rtrim(" ".str_replace("\n", "\n ", $text)); return rtrim(" ".str_replace("\n", "\n ", $text));
} }
private function newMarkupEngine() {
$engine = PhabricatorMarkupEngine::newMarkupEngine(array())
->setConfig('viewer', $this->getViewer())
->setConfig('uri.base', PhabricatorEnv::getProductionURI('/'));
$context = $this->getContextObject();
if ($context) {
$engine->setConfig('contextObject', $context);
}
return $engine;
}
} }

View file

@ -28,17 +28,7 @@ final class PhrictionRemarkupRule extends PhutilRemarkupRule {
// Handle relative links. // Handle relative links.
if ((substr($link, 0, 2) === './') || (substr($link, 0, 3) === '../')) { if ((substr($link, 0, 2) === './') || (substr($link, 0, 3) === '../')) {
$base = null; $base = $this->getRelativeBaseURI();
$context = $this->getEngine()->getConfig('contextObject');
if ($context !== null && $context instanceof PhrictionContent) {
// Handle content when it's being rendered in document view.
$base = $context->getSlug();
}
if ($context !== null && is_array($context) &&
idx($context, 'phriction.isPreview')) {
// Handle content when it's a preview for the Phriction editor.
$base = idx($context, 'phriction.slug');
}
if ($base !== null) { if ($base !== null) {
$base_parts = explode('/', rtrim($base, '/')); $base_parts = explode('/', rtrim($base, '/'));
$rel_parts = explode('/', rtrim($link, '/')); $rel_parts = explode('/', rtrim($link, '/'));
@ -195,4 +185,30 @@ final class PhrictionRemarkupRule extends PhutilRemarkupRule {
} }
} }
private function getRelativeBaseURI() {
$context = $this->getEngine()->getConfig('contextObject');
if (!$context) {
return null;
}
// Handle content when it's a preview for the Phriction editor.
if (is_array($context)) {
if (idx($context, 'phriction.isPreview')) {
return idx($context, 'phriction.slug');
}
}
if ($context instanceof PhrictionContent) {
return $context->getSlug();
}
if ($context instanceof PhrictionDocument) {
return $context->getSlug();
}
return null;
}
} }

View file

@ -2880,11 +2880,13 @@ abstract class PhabricatorApplicationTransactionEditor
PhabricatorLiskDAO $object, PhabricatorLiskDAO $object,
array $xactions) { array $xactions) {
$body = new PhabricatorMetaMTAMailBody(); $body = id(new PhabricatorMetaMTAMailBody())
$body->setViewer($this->requireActor()); ->setViewer($this->requireActor())
->setContextObject($object);
$this->addHeadersAndCommentsToMailBody($body, $xactions); $this->addHeadersAndCommentsToMailBody($body, $xactions);
$this->addCustomFieldsToMailBody($body, $object, $xactions); $this->addCustomFieldsToMailBody($body, $object, $xactions);
return $body; return $body;
} }