mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-13 18:32:41 +01:00
d0127f95e5
Summary: also try to centralize some of the command parsing logic. note that differential is still an exception here. it uses a whitelist-style regex. i think long-term we should have this for every app but changing it seemed too big for this diff. Fixes T3937. Test Plan: echo '!assign btrahan' | ./bin/mail receive-test --as xerxes --to T22 ; echo '!claim' | ./bin/mail receive-test --as xerxes --to T22 unit tests passed, though my new one is silly Reviewers: epriestley Reviewed By: epriestley CC: Korvin, epriestley, aran Maniphest Tasks: T3937 Differential Revision: https://secure.phabricator.com/D7307
81 lines
2.3 KiB
PHP
81 lines
2.3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group file
|
|
*/
|
|
final class FileReplyHandler extends PhabricatorMailReplyHandler {
|
|
|
|
public function validateMailReceiver($mail_receiver) {
|
|
if (!($mail_receiver instanceof PhabricatorFile)) {
|
|
throw new Exception('Mail receiver is not a PhabricatorFile.');
|
|
}
|
|
}
|
|
|
|
public function getPrivateReplyHandlerEmailAddress(
|
|
PhabricatorObjectHandle $handle) {
|
|
return $this->getDefaultPrivateReplyHandlerEmailAddress($handle, 'F');
|
|
}
|
|
|
|
public function getPublicReplyHandlerEmailAddress() {
|
|
return $this->getDefaultPublicReplyHandlerEmailAddress('F');
|
|
}
|
|
|
|
public function getReplyHandlerInstructions() {
|
|
if ($this->supportsReplies()) {
|
|
return pht('Reply to comment or !unsubscribe.');
|
|
} else {
|
|
return null;
|
|
}
|
|
}
|
|
|
|
protected function receiveEmail(PhabricatorMetaMTAReceivedMail $mail) {
|
|
$actor = $this->getActor();
|
|
$file = $this->getMailReceiver();
|
|
|
|
$body_data = $mail->parseBody();
|
|
$body = $body_data['body'];
|
|
$body = $this->enhanceBodyWithAttachments($body, $mail->getAttachments());
|
|
|
|
$content_source = PhabricatorContentSource::newForSource(
|
|
PhabricatorContentSource::SOURCE_EMAIL,
|
|
array(
|
|
'id' => $mail->getID(),
|
|
));
|
|
|
|
$xactions = array();
|
|
$command = $body_data['body'];
|
|
|
|
switch ($command) {
|
|
case 'unsubscribe':
|
|
$xaction = id(new PhabricatorFileTransaction())
|
|
->setTransactionType(PhabricatorTransactions::TYPE_SUBSCRIBERS)
|
|
->setNewValue(array('-' => array($actor->getPHID())));
|
|
$xactions[] = $xaction;
|
|
break;
|
|
}
|
|
|
|
$xactions[] = id(new PhabricatorFileTransaction())
|
|
->setTransactionType(PhabricatorTransactions::TYPE_COMMENT)
|
|
->attachComment(
|
|
id(new PhabricatorFileTransactionComment())
|
|
->setContent($body));
|
|
|
|
$editor = id(new PhabricatorFileEditor())
|
|
->setActor($actor)
|
|
->setContentSource($content_source)
|
|
->setContinueOnNoEffect(true)
|
|
->setIsPreview(false);
|
|
|
|
try {
|
|
$xactions = $editor->applyTransactions($file, $xactions);
|
|
} catch (PhabricatorApplicationTransactionNoEffectException $ex) {
|
|
// just do nothing, though unclear why you're sending a blank email
|
|
return true;
|
|
}
|
|
|
|
$head_xaction = head($xactions);
|
|
return $head_xaction->getID();
|
|
|
|
}
|
|
|
|
}
|