Correct a parameter order swap in "diffusion.historyquery" for Mercurial
[phabricator.git] / src / applications / releeph / controller / request / ReleephRequestCommentController.php
blob96500e8bc5a6db0d562be2b970dd14635a870257
1 <?php
3 final class ReleephRequestCommentController
4 extends ReleephRequestController {
6 public function handleRequest(AphrontRequest $request) {
7 $id = $request->getURIData('requestID');
8 $viewer = $request->getViewer();
10 if (!$request->isFormPost()) {
11 return new Aphront400Response();
14 $pull = id(new ReleephRequestQuery())
15 ->setViewer($viewer)
16 ->withIDs(array($id))
17 ->executeOne();
18 if (!$pull) {
19 return new Aphront404Response();
22 $is_preview = $request->isPreviewRequest();
23 $draft = PhabricatorDraft::buildFromRequest($request);
25 $view_uri = $this->getApplicationURI('/'.$pull->getMonogram());
27 $xactions = array();
28 $xactions[] = id(new ReleephRequestTransaction())
29 ->setTransactionType(PhabricatorTransactions::TYPE_COMMENT)
30 ->attachComment(
31 id(new ReleephRequestTransactionComment())
32 ->setContent($request->getStr('comment')));
34 $editor = id(new ReleephRequestTransactionalEditor())
35 ->setActor($viewer)
36 ->setContinueOnNoEffect($request->isContinueRequest())
37 ->setContentSourceFromRequest($request)
38 ->setIsPreview($is_preview);
40 try {
41 $xactions = $editor->applyTransactions($pull, $xactions);
42 } catch (PhabricatorApplicationTransactionNoEffectException $ex) {
43 return id(new PhabricatorApplicationTransactionNoEffectResponse())
44 ->setCancelURI($view_uri)
45 ->setException($ex);
48 if ($draft) {
49 $draft->replaceOrDelete();
52 if ($request->isAjax() && $is_preview) {
53 return id(new PhabricatorApplicationTransactionResponse())
54 ->setObject($pull)
55 ->setViewer($viewer)
56 ->setTransactions($xactions)
57 ->setIsPreview($is_preview);
58 } else {
59 return id(new AphrontRedirectResponse())
60 ->setURI($view_uri);