mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-02 02:40:58 +01:00
Provide application and object level policy controls in Slowvote
Summary: Ref T603. Gives the create/edit interface a policy control, and adds an application-level default. Test Plan: Created and edited polls. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T603 Differential Revision: https://secure.phabricator.com/D7321
This commit is contained in:
parent
8c1c6fec5a
commit
e381022bc7
5 changed files with 64 additions and 3 deletions
|
@ -1665,6 +1665,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorSetupIssue' => 'applications/config/issue/PhabricatorSetupIssue.php',
|
'PhabricatorSetupIssue' => 'applications/config/issue/PhabricatorSetupIssue.php',
|
||||||
'PhabricatorSetupIssueExample' => 'applications/uiexample/examples/PhabricatorSetupIssueExample.php',
|
'PhabricatorSetupIssueExample' => 'applications/uiexample/examples/PhabricatorSetupIssueExample.php',
|
||||||
'PhabricatorSetupIssueView' => 'applications/config/view/PhabricatorSetupIssueView.php',
|
'PhabricatorSetupIssueView' => 'applications/config/view/PhabricatorSetupIssueView.php',
|
||||||
|
'PhabricatorSlowvoteCapabilityDefaultView' => 'applications/slowvote/capability/PhabricatorSlowvoteCapabilityDefaultView.php',
|
||||||
'PhabricatorSlowvoteChoice' => 'applications/slowvote/storage/PhabricatorSlowvoteChoice.php',
|
'PhabricatorSlowvoteChoice' => 'applications/slowvote/storage/PhabricatorSlowvoteChoice.php',
|
||||||
'PhabricatorSlowvoteComment' => 'applications/slowvote/storage/PhabricatorSlowvoteComment.php',
|
'PhabricatorSlowvoteComment' => 'applications/slowvote/storage/PhabricatorSlowvoteComment.php',
|
||||||
'PhabricatorSlowvoteCommentController' => 'applications/slowvote/controller/PhabricatorSlowvoteCommentController.php',
|
'PhabricatorSlowvoteCommentController' => 'applications/slowvote/controller/PhabricatorSlowvoteCommentController.php',
|
||||||
|
@ -3876,6 +3877,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorSetupCheckTimezone' => 'PhabricatorSetupCheck',
|
'PhabricatorSetupCheckTimezone' => 'PhabricatorSetupCheck',
|
||||||
'PhabricatorSetupIssueExample' => 'PhabricatorUIExample',
|
'PhabricatorSetupIssueExample' => 'PhabricatorUIExample',
|
||||||
'PhabricatorSetupIssueView' => 'AphrontView',
|
'PhabricatorSetupIssueView' => 'AphrontView',
|
||||||
|
'PhabricatorSlowvoteCapabilityDefaultView' => 'PhabricatorPolicyCapability',
|
||||||
'PhabricatorSlowvoteChoice' => 'PhabricatorSlowvoteDAO',
|
'PhabricatorSlowvoteChoice' => 'PhabricatorSlowvoteDAO',
|
||||||
'PhabricatorSlowvoteComment' => 'PhabricatorSlowvoteDAO',
|
'PhabricatorSlowvoteComment' => 'PhabricatorSlowvoteDAO',
|
||||||
'PhabricatorSlowvoteCommentController' => 'PhabricatorSlowvoteController',
|
'PhabricatorSlowvoteCommentController' => 'PhabricatorSlowvoteController',
|
||||||
|
|
|
@ -50,4 +50,12 @@ final class PhabricatorApplicationSlowvote extends PhabricatorApplication {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getCustomCapabilities() {
|
||||||
|
return array(
|
||||||
|
PhabricatorSlowvoteCapabilityDefaultView::CAPABILITY => array(
|
||||||
|
'caption' => pht('Default view policy for new polls.'),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorSlowvoteCapabilityDefaultView
|
||||||
|
extends PhabricatorPolicyCapability {
|
||||||
|
|
||||||
|
const CAPABILITY = 'slowvote.default.view';
|
||||||
|
|
||||||
|
public function getCapabilityKey() {
|
||||||
|
return self::CAPABILITY;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getCapabilityName() {
|
||||||
|
return pht('Default View Policy');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function shouldAllowPublicPolicySetting() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -32,9 +32,7 @@ final class PhabricatorSlowvoteEditController
|
||||||
}
|
}
|
||||||
$is_new = false;
|
$is_new = false;
|
||||||
} else {
|
} else {
|
||||||
$poll = id(new PhabricatorSlowvotePoll())
|
$poll = PhabricatorSlowvotePoll::initializeNewPoll($user);
|
||||||
->setAuthorPHID($user->getPHID())
|
|
||||||
->setViewPolicy(PhabricatorPolicies::POLICY_USER);
|
|
||||||
$is_new = true;
|
$is_new = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,6 +51,7 @@ final class PhabricatorSlowvoteEditController
|
||||||
$v_description = $request->getStr('description');
|
$v_description = $request->getStr('description');
|
||||||
$v_responses = (int)$request->getInt('responses');
|
$v_responses = (int)$request->getInt('responses');
|
||||||
$v_shuffle = (int)$request->getBool('shuffle');
|
$v_shuffle = (int)$request->getBool('shuffle');
|
||||||
|
$v_view_policy = $request->getStr('viewPolicy');
|
||||||
|
|
||||||
if ($is_new) {
|
if ($is_new) {
|
||||||
$poll->setMethod($request->getInt('method'));
|
$poll->setMethod($request->getInt('method'));
|
||||||
|
@ -94,6 +93,10 @@ final class PhabricatorSlowvoteEditController
|
||||||
->setTransactionType(PhabricatorSlowvoteTransaction::TYPE_SHUFFLE)
|
->setTransactionType(PhabricatorSlowvoteTransaction::TYPE_SHUFFLE)
|
||||||
->setNewValue($v_shuffle);
|
->setNewValue($v_shuffle);
|
||||||
|
|
||||||
|
$xactions[] = id(clone $template)
|
||||||
|
->setTransactionType(PhabricatorTransactions::TYPE_VIEW_POLICY)
|
||||||
|
->setNewValue($v_view_policy);
|
||||||
|
|
||||||
if (empty($errors)) {
|
if (empty($errors)) {
|
||||||
$editor = id(new PhabricatorSlowvoteEditor())
|
$editor = id(new PhabricatorSlowvoteEditor())
|
||||||
->setActor($user)
|
->setActor($user)
|
||||||
|
@ -115,6 +118,8 @@ final class PhabricatorSlowvoteEditController
|
||||||
|
|
||||||
return id(new AphrontRedirectResponse())
|
return id(new AphrontRedirectResponse())
|
||||||
->setURI('/V'.$poll->getID());
|
->setURI('/V'.$poll->getID());
|
||||||
|
} else {
|
||||||
|
$poll->setViewPolicy($v_view_policy);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -206,6 +211,11 @@ final class PhabricatorSlowvoteEditController
|
||||||
$cancel_uri = '/V'.$poll->getID();
|
$cancel_uri = '/V'.$poll->getID();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$policies = id(new PhabricatorPolicyQuery())
|
||||||
|
->setViewer($user)
|
||||||
|
->setObject($poll)
|
||||||
|
->execute();
|
||||||
|
|
||||||
$form
|
$form
|
||||||
->appendChild(
|
->appendChild(
|
||||||
id(new AphrontFormSelectControl())
|
id(new AphrontFormSelectControl())
|
||||||
|
@ -221,6 +231,13 @@ final class PhabricatorSlowvoteEditController
|
||||||
1,
|
1,
|
||||||
pht('Show choices in random order.'),
|
pht('Show choices in random order.'),
|
||||||
$v_shuffle))
|
$v_shuffle))
|
||||||
|
->appendChild(
|
||||||
|
id(new AphrontFormPolicyControl())
|
||||||
|
->setUser($user)
|
||||||
|
->setName('viewPolicy')
|
||||||
|
->setPolicyObject($poll)
|
||||||
|
->setPolicies($policies)
|
||||||
|
->setCapability(PhabricatorPolicyCapability::CAN_VIEW))
|
||||||
->appendChild(
|
->appendChild(
|
||||||
id(new AphrontFormSubmitControl())
|
id(new AphrontFormSubmitControl())
|
||||||
->setValue($button)
|
->setValue($button)
|
||||||
|
|
|
@ -28,6 +28,20 @@ final class PhabricatorSlowvotePoll extends PhabricatorSlowvoteDAO
|
||||||
private $choices = self::ATTACHABLE;
|
private $choices = self::ATTACHABLE;
|
||||||
private $viewerChoices = self::ATTACHABLE;
|
private $viewerChoices = self::ATTACHABLE;
|
||||||
|
|
||||||
|
public static function initializeNewPoll(PhabricatorUser $actor) {
|
||||||
|
$app = id(new PhabricatorApplicationQuery())
|
||||||
|
->setViewer($actor)
|
||||||
|
->withClasses(array('PhabricatorApplicationSlowvote'))
|
||||||
|
->executeOne();
|
||||||
|
|
||||||
|
$view_policy = $app->getPolicy(
|
||||||
|
PhabricatorSlowvoteCapabilityDefaultView::CAPABILITY);
|
||||||
|
|
||||||
|
return id(new PhabricatorSlowvotePoll())
|
||||||
|
->setAuthorPHID($actor->getPHID())
|
||||||
|
->setViewPolicy($view_policy);
|
||||||
|
}
|
||||||
|
|
||||||
public function getConfiguration() {
|
public function getConfiguration() {
|
||||||
return array(
|
return array(
|
||||||
self::CONFIG_AUX_PHID => true,
|
self::CONFIG_AUX_PHID => true,
|
||||||
|
|
Loading…
Reference in a new issue