mirror of
https://we.phorge.it/source/phorge.git
synced 2025-02-10 05:48:30 +01:00
44f18cfb12
Summary: Updates Projects to use handleRequest Test Plan: New Project, Edit Project, Archive, Watch, Create Workboards, Import Workboards, Edit Column, New Column, Change Icon, Add/Remove Members Reviewers: epriestley Reviewed By: epriestley Subscribers: Korvin Differential Revision: https://secure.phabricator.com/D13829
112 lines
3.3 KiB
PHP
112 lines
3.3 KiB
PHP
<?php
|
|
|
|
final class PhabricatorProjectUpdateController
|
|
extends PhabricatorProjectController {
|
|
|
|
public function handleRequest(AphrontRequest $request) {
|
|
$viewer = $request->getViewer();
|
|
$id = $request->getURIData('id');
|
|
$action = $request->getURIData('action');
|
|
|
|
$capabilities = array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
);
|
|
|
|
$process_action = false;
|
|
switch ($action) {
|
|
case 'join':
|
|
$capabilities[] = PhabricatorPolicyCapability::CAN_JOIN;
|
|
$process_action = $request->isFormPost();
|
|
break;
|
|
case 'leave':
|
|
$process_action = $request->isDialogFormPost();
|
|
break;
|
|
default:
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$project = id(new PhabricatorProjectQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($id))
|
|
->needMembers(true)
|
|
->requireCapabilities($capabilities)
|
|
->executeOne();
|
|
if (!$project) {
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
$project_uri = $this->getApplicationURI('profile/'.$project->getID().'/');
|
|
|
|
if ($process_action) {
|
|
|
|
$edge_action = null;
|
|
switch ($action) {
|
|
case 'join':
|
|
$edge_action = '+';
|
|
break;
|
|
case 'leave':
|
|
$edge_action = '-';
|
|
break;
|
|
}
|
|
|
|
$type_member = PhabricatorProjectProjectHasMemberEdgeType::EDGECONST;
|
|
$member_spec = array(
|
|
$edge_action => array($viewer->getPHID() => $viewer->getPHID()),
|
|
);
|
|
|
|
$xactions = array();
|
|
$xactions[] = id(new PhabricatorProjectTransaction())
|
|
->setTransactionType(PhabricatorTransactions::TYPE_EDGE)
|
|
->setMetadataValue('edge:type', $type_member)
|
|
->setNewValue($member_spec);
|
|
|
|
$editor = id(new PhabricatorProjectTransactionEditor($project))
|
|
->setActor($viewer)
|
|
->setContentSourceFromRequest($request)
|
|
->setContinueOnNoEffect(true)
|
|
->setContinueOnMissingFields(true)
|
|
->applyTransactions($project, $xactions);
|
|
|
|
return id(new AphrontRedirectResponse())->setURI($project_uri);
|
|
}
|
|
|
|
$dialog = null;
|
|
switch ($action) {
|
|
case 'leave':
|
|
$dialog = new AphrontDialogView();
|
|
$dialog->setUser($viewer);
|
|
if ($this->userCannotLeave($project)) {
|
|
$dialog->setTitle(pht('You can not leave this project.'));
|
|
$body = pht('The membership is locked for this project.');
|
|
} else {
|
|
$dialog->setTitle(pht('Really leave project?'));
|
|
$body = pht(
|
|
'Your tremendous contributions to this project will be sorely '.
|
|
'missed. Are you sure you want to leave?');
|
|
$dialog->addSubmitButton(pht('Leave Project'));
|
|
}
|
|
$dialog->appendParagraph($body);
|
|
$dialog->addCancelButton($project_uri);
|
|
break;
|
|
default:
|
|
return new Aphront404Response();
|
|
}
|
|
|
|
return id(new AphrontDialogResponse())->setDialog($dialog);
|
|
}
|
|
|
|
/**
|
|
* This is enforced in @{class:PhabricatorProjectTransactionEditor}. We use
|
|
* this logic to render a better form for users hitting this case.
|
|
*/
|
|
private function userCannotLeave(PhabricatorProject $project) {
|
|
$viewer = $this->getViewer();
|
|
|
|
return
|
|
$project->getIsMembershipLocked() &&
|
|
!PhabricatorPolicyFilter::hasCapability(
|
|
$viewer,
|
|
$project,
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
}
|
|
}
|