mirror of
https://we.phorge.it/source/phorge.git
synced 2024-09-22 10:18:48 +02:00
baf2ea5b32
Summary: Drop the "Pro" bit. Test Plan: Created/edited tasks, moved tasks around, generally made a mess. Nothing burned down. Reviewers: btrahan Reviewed By: btrahan CC: aran Differential Revision: https://secure.phabricator.com/D7352
51 lines
1.2 KiB
PHP
51 lines
1.2 KiB
PHP
<?php
|
|
|
|
final class ManiphestSubscribeController extends ManiphestController {
|
|
|
|
private $id;
|
|
private $action;
|
|
|
|
public function willProcessRequest(array $data) {
|
|
$this->id = $data['id'];
|
|
$this->action = $data['action'];
|
|
}
|
|
|
|
public function processRequest() {
|
|
|
|
$request = $this->getRequest();
|
|
$user = $request->getUser();
|
|
|
|
$task = id(new ManiphestTaskQuery())
|
|
->setViewer($user)
|
|
->withIDs(array($this->id))
|
|
->executeOne();
|
|
if (!$task) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$ccs = $task->getCCPHIDs();
|
|
switch ($this->action) {
|
|
case 'add':
|
|
$ccs[] = $user->getPHID();
|
|
break;
|
|
case 'rem':
|
|
$ccs = array_diff($ccs, array($user->getPHID()));
|
|
break;
|
|
default:
|
|
return new Aphront400Response();
|
|
}
|
|
|
|
$xaction = id(new ManiphestTransaction())
|
|
->setTransactionType(ManiphestTransaction::TYPE_CCS)
|
|
->setNewValue($ccs);
|
|
|
|
$editor = id(new ManiphestTransactionEditor())
|
|
->setActor($user)
|
|
->setContentSourceFromRequest($request)
|
|
->setContinueOnNoEffect(true)
|
|
->setContinueOnMissingFields(true)
|
|
->applyTransactions($task, array($xaction));
|
|
|
|
return id(new AphrontRedirectResponse())->setURI('/T'.$task->getID());
|
|
}
|
|
}
|