mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-24 05:28:18 +01:00
Reimplement Slowvote transactions using modular transactions
Summary: Fixes T12623. Adds new modular transactions to Slowvote. Also converts the `shuffle` column to `bool` for consistency with other boolean-ish columns. Test Plan: Create a new vote, modified everything that could be modified from the web UI, observed expected timeline. Example timeline: {F4938843} Example transaction values in DB: {F4938850} Reviewers: #blessed_reviewers, epriestley Reviewed By: #blessed_reviewers, epriestley Subscribers: Korvin, epriestley Maniphest Tasks: T12623 Differential Revision: https://secure.phabricator.com/D17830
This commit is contained in:
parent
836819a0e7
commit
0dc90b891a
13 changed files with 323 additions and 333 deletions
|
@ -0,0 +1,2 @@
|
||||||
|
ALTER TABLE {$NAMESPACE}_slowvote.slowvote_poll
|
||||||
|
MODIFY shuffle BOOL NOT NULL DEFAULT 0;
|
|
@ -3901,10 +3901,12 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorSlowvoteApplication' => 'applications/slowvote/application/PhabricatorSlowvoteApplication.php',
|
'PhabricatorSlowvoteApplication' => 'applications/slowvote/application/PhabricatorSlowvoteApplication.php',
|
||||||
'PhabricatorSlowvoteChoice' => 'applications/slowvote/storage/PhabricatorSlowvoteChoice.php',
|
'PhabricatorSlowvoteChoice' => 'applications/slowvote/storage/PhabricatorSlowvoteChoice.php',
|
||||||
'PhabricatorSlowvoteCloseController' => 'applications/slowvote/controller/PhabricatorSlowvoteCloseController.php',
|
'PhabricatorSlowvoteCloseController' => 'applications/slowvote/controller/PhabricatorSlowvoteCloseController.php',
|
||||||
|
'PhabricatorSlowvoteCloseTransaction' => 'applications/slowvote/xactions/PhabricatorSlowvoteCloseTransaction.php',
|
||||||
'PhabricatorSlowvoteCommentController' => 'applications/slowvote/controller/PhabricatorSlowvoteCommentController.php',
|
'PhabricatorSlowvoteCommentController' => 'applications/slowvote/controller/PhabricatorSlowvoteCommentController.php',
|
||||||
'PhabricatorSlowvoteController' => 'applications/slowvote/controller/PhabricatorSlowvoteController.php',
|
'PhabricatorSlowvoteController' => 'applications/slowvote/controller/PhabricatorSlowvoteController.php',
|
||||||
'PhabricatorSlowvoteDAO' => 'applications/slowvote/storage/PhabricatorSlowvoteDAO.php',
|
'PhabricatorSlowvoteDAO' => 'applications/slowvote/storage/PhabricatorSlowvoteDAO.php',
|
||||||
'PhabricatorSlowvoteDefaultViewCapability' => 'applications/slowvote/capability/PhabricatorSlowvoteDefaultViewCapability.php',
|
'PhabricatorSlowvoteDefaultViewCapability' => 'applications/slowvote/capability/PhabricatorSlowvoteDefaultViewCapability.php',
|
||||||
|
'PhabricatorSlowvoteDescriptionTransaction' => 'applications/slowvote/xactions/PhabricatorSlowvoteDescriptionTransaction.php',
|
||||||
'PhabricatorSlowvoteEditController' => 'applications/slowvote/controller/PhabricatorSlowvoteEditController.php',
|
'PhabricatorSlowvoteEditController' => 'applications/slowvote/controller/PhabricatorSlowvoteEditController.php',
|
||||||
'PhabricatorSlowvoteEditor' => 'applications/slowvote/editor/PhabricatorSlowvoteEditor.php',
|
'PhabricatorSlowvoteEditor' => 'applications/slowvote/editor/PhabricatorSlowvoteEditor.php',
|
||||||
'PhabricatorSlowvoteListController' => 'applications/slowvote/controller/PhabricatorSlowvoteListController.php',
|
'PhabricatorSlowvoteListController' => 'applications/slowvote/controller/PhabricatorSlowvoteListController.php',
|
||||||
|
@ -3914,12 +3916,16 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorSlowvotePollController' => 'applications/slowvote/controller/PhabricatorSlowvotePollController.php',
|
'PhabricatorSlowvotePollController' => 'applications/slowvote/controller/PhabricatorSlowvotePollController.php',
|
||||||
'PhabricatorSlowvotePollPHIDType' => 'applications/slowvote/phid/PhabricatorSlowvotePollPHIDType.php',
|
'PhabricatorSlowvotePollPHIDType' => 'applications/slowvote/phid/PhabricatorSlowvotePollPHIDType.php',
|
||||||
'PhabricatorSlowvoteQuery' => 'applications/slowvote/query/PhabricatorSlowvoteQuery.php',
|
'PhabricatorSlowvoteQuery' => 'applications/slowvote/query/PhabricatorSlowvoteQuery.php',
|
||||||
|
'PhabricatorSlowvoteQuestionTransaction' => 'applications/slowvote/xactions/PhabricatorSlowvoteQuestionTransaction.php',
|
||||||
'PhabricatorSlowvoteReplyHandler' => 'applications/slowvote/mail/PhabricatorSlowvoteReplyHandler.php',
|
'PhabricatorSlowvoteReplyHandler' => 'applications/slowvote/mail/PhabricatorSlowvoteReplyHandler.php',
|
||||||
|
'PhabricatorSlowvoteResponsesTransaction' => 'applications/slowvote/xactions/PhabricatorSlowvoteResponsesTransaction.php',
|
||||||
'PhabricatorSlowvoteSchemaSpec' => 'applications/slowvote/storage/PhabricatorSlowvoteSchemaSpec.php',
|
'PhabricatorSlowvoteSchemaSpec' => 'applications/slowvote/storage/PhabricatorSlowvoteSchemaSpec.php',
|
||||||
'PhabricatorSlowvoteSearchEngine' => 'applications/slowvote/query/PhabricatorSlowvoteSearchEngine.php',
|
'PhabricatorSlowvoteSearchEngine' => 'applications/slowvote/query/PhabricatorSlowvoteSearchEngine.php',
|
||||||
|
'PhabricatorSlowvoteShuffleTransaction' => 'applications/slowvote/xactions/PhabricatorSlowvoteShuffleTransaction.php',
|
||||||
'PhabricatorSlowvoteTransaction' => 'applications/slowvote/storage/PhabricatorSlowvoteTransaction.php',
|
'PhabricatorSlowvoteTransaction' => 'applications/slowvote/storage/PhabricatorSlowvoteTransaction.php',
|
||||||
'PhabricatorSlowvoteTransactionComment' => 'applications/slowvote/storage/PhabricatorSlowvoteTransactionComment.php',
|
'PhabricatorSlowvoteTransactionComment' => 'applications/slowvote/storage/PhabricatorSlowvoteTransactionComment.php',
|
||||||
'PhabricatorSlowvoteTransactionQuery' => 'applications/slowvote/query/PhabricatorSlowvoteTransactionQuery.php',
|
'PhabricatorSlowvoteTransactionQuery' => 'applications/slowvote/query/PhabricatorSlowvoteTransactionQuery.php',
|
||||||
|
'PhabricatorSlowvoteTransactionType' => 'applications/slowvote/xactions/PhabricatorSlowvoteTransactionType.php',
|
||||||
'PhabricatorSlowvoteVoteController' => 'applications/slowvote/controller/PhabricatorSlowvoteVoteController.php',
|
'PhabricatorSlowvoteVoteController' => 'applications/slowvote/controller/PhabricatorSlowvoteVoteController.php',
|
||||||
'PhabricatorSlug' => 'infrastructure/util/PhabricatorSlug.php',
|
'PhabricatorSlug' => 'infrastructure/util/PhabricatorSlug.php',
|
||||||
'PhabricatorSlugTestCase' => 'infrastructure/util/__tests__/PhabricatorSlugTestCase.php',
|
'PhabricatorSlugTestCase' => 'infrastructure/util/__tests__/PhabricatorSlugTestCase.php',
|
||||||
|
@ -9327,10 +9333,12 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorSlowvoteApplication' => 'PhabricatorApplication',
|
'PhabricatorSlowvoteApplication' => 'PhabricatorApplication',
|
||||||
'PhabricatorSlowvoteChoice' => 'PhabricatorSlowvoteDAO',
|
'PhabricatorSlowvoteChoice' => 'PhabricatorSlowvoteDAO',
|
||||||
'PhabricatorSlowvoteCloseController' => 'PhabricatorSlowvoteController',
|
'PhabricatorSlowvoteCloseController' => 'PhabricatorSlowvoteController',
|
||||||
|
'PhabricatorSlowvoteCloseTransaction' => 'PhabricatorSlowvoteTransactionType',
|
||||||
'PhabricatorSlowvoteCommentController' => 'PhabricatorSlowvoteController',
|
'PhabricatorSlowvoteCommentController' => 'PhabricatorSlowvoteController',
|
||||||
'PhabricatorSlowvoteController' => 'PhabricatorController',
|
'PhabricatorSlowvoteController' => 'PhabricatorController',
|
||||||
'PhabricatorSlowvoteDAO' => 'PhabricatorLiskDAO',
|
'PhabricatorSlowvoteDAO' => 'PhabricatorLiskDAO',
|
||||||
'PhabricatorSlowvoteDefaultViewCapability' => 'PhabricatorPolicyCapability',
|
'PhabricatorSlowvoteDefaultViewCapability' => 'PhabricatorPolicyCapability',
|
||||||
|
'PhabricatorSlowvoteDescriptionTransaction' => 'PhabricatorSlowvoteTransactionType',
|
||||||
'PhabricatorSlowvoteEditController' => 'PhabricatorSlowvoteController',
|
'PhabricatorSlowvoteEditController' => 'PhabricatorSlowvoteController',
|
||||||
'PhabricatorSlowvoteEditor' => 'PhabricatorApplicationTransactionEditor',
|
'PhabricatorSlowvoteEditor' => 'PhabricatorApplicationTransactionEditor',
|
||||||
'PhabricatorSlowvoteListController' => 'PhabricatorSlowvoteController',
|
'PhabricatorSlowvoteListController' => 'PhabricatorSlowvoteController',
|
||||||
|
@ -9350,12 +9358,16 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorSlowvotePollController' => 'PhabricatorSlowvoteController',
|
'PhabricatorSlowvotePollController' => 'PhabricatorSlowvoteController',
|
||||||
'PhabricatorSlowvotePollPHIDType' => 'PhabricatorPHIDType',
|
'PhabricatorSlowvotePollPHIDType' => 'PhabricatorPHIDType',
|
||||||
'PhabricatorSlowvoteQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
'PhabricatorSlowvoteQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
||||||
|
'PhabricatorSlowvoteQuestionTransaction' => 'PhabricatorSlowvoteTransactionType',
|
||||||
'PhabricatorSlowvoteReplyHandler' => 'PhabricatorApplicationTransactionReplyHandler',
|
'PhabricatorSlowvoteReplyHandler' => 'PhabricatorApplicationTransactionReplyHandler',
|
||||||
|
'PhabricatorSlowvoteResponsesTransaction' => 'PhabricatorSlowvoteTransactionType',
|
||||||
'PhabricatorSlowvoteSchemaSpec' => 'PhabricatorConfigSchemaSpec',
|
'PhabricatorSlowvoteSchemaSpec' => 'PhabricatorConfigSchemaSpec',
|
||||||
'PhabricatorSlowvoteSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
'PhabricatorSlowvoteSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
||||||
'PhabricatorSlowvoteTransaction' => 'PhabricatorApplicationTransaction',
|
'PhabricatorSlowvoteShuffleTransaction' => 'PhabricatorSlowvoteTransactionType',
|
||||||
|
'PhabricatorSlowvoteTransaction' => 'PhabricatorModularTransaction',
|
||||||
'PhabricatorSlowvoteTransactionComment' => 'PhabricatorApplicationTransactionComment',
|
'PhabricatorSlowvoteTransactionComment' => 'PhabricatorApplicationTransactionComment',
|
||||||
'PhabricatorSlowvoteTransactionQuery' => 'PhabricatorApplicationTransactionQuery',
|
'PhabricatorSlowvoteTransactionQuery' => 'PhabricatorApplicationTransactionQuery',
|
||||||
|
'PhabricatorSlowvoteTransactionType' => 'PhabricatorModularTransactionType',
|
||||||
'PhabricatorSlowvoteVoteController' => 'PhabricatorSlowvoteController',
|
'PhabricatorSlowvoteVoteController' => 'PhabricatorSlowvoteController',
|
||||||
'PhabricatorSlug' => 'Phobject',
|
'PhabricatorSlug' => 'Phobject',
|
||||||
'PhabricatorSlugTestCase' => 'PhabricatorTestCase',
|
'PhabricatorSlugTestCase' => 'PhabricatorTestCase',
|
||||||
|
|
|
@ -32,7 +32,8 @@ final class PhabricatorSlowvoteCloseController
|
||||||
$xactions = array();
|
$xactions = array();
|
||||||
|
|
||||||
$xactions[] = id(new PhabricatorSlowvoteTransaction())
|
$xactions[] = id(new PhabricatorSlowvoteTransaction())
|
||||||
->setTransactionType(PhabricatorSlowvoteTransaction::TYPE_CLOSE)
|
->setTransactionType(
|
||||||
|
PhabricatorSlowvoteCloseTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($new_status);
|
->setNewValue($new_status);
|
||||||
|
|
||||||
id(new PhabricatorSlowvoteEditor())
|
id(new PhabricatorSlowvoteEditor())
|
||||||
|
|
|
@ -77,23 +77,32 @@ final class PhabricatorSlowvoteEditController
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$xactions = array();
|
|
||||||
$template = id(new PhabricatorSlowvoteTransaction());
|
$template = id(new PhabricatorSlowvoteTransaction());
|
||||||
|
$xactions = array();
|
||||||
|
|
||||||
|
if ($is_new) {
|
||||||
|
$xactions[] = id(new PhabricatorSlowvoteTransaction())
|
||||||
|
->setTransactionType(PhabricatorTransactions::TYPE_CREATE);
|
||||||
|
}
|
||||||
|
|
||||||
$xactions[] = id(clone $template)
|
$xactions[] = id(clone $template)
|
||||||
->setTransactionType(PhabricatorSlowvoteTransaction::TYPE_QUESTION)
|
->setTransactionType(
|
||||||
|
PhabricatorSlowvoteQuestionTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($v_question);
|
->setNewValue($v_question);
|
||||||
|
|
||||||
$xactions[] = id(clone $template)
|
$xactions[] = id(clone $template)
|
||||||
->setTransactionType(PhabricatorSlowvoteTransaction::TYPE_DESCRIPTION)
|
->setTransactionType(
|
||||||
|
PhabricatorSlowvoteDescriptionTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($v_description);
|
->setNewValue($v_description);
|
||||||
|
|
||||||
$xactions[] = id(clone $template)
|
$xactions[] = id(clone $template)
|
||||||
->setTransactionType(PhabricatorSlowvoteTransaction::TYPE_RESPONSES)
|
->setTransactionType(
|
||||||
|
PhabricatorSlowvoteResponsesTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($v_responses);
|
->setNewValue($v_responses);
|
||||||
|
|
||||||
$xactions[] = id(clone $template)
|
$xactions[] = id(clone $template)
|
||||||
->setTransactionType(PhabricatorSlowvoteTransaction::TYPE_SHUFFLE)
|
->setTransactionType(
|
||||||
|
PhabricatorSlowvoteShuffleTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($v_shuffle);
|
->setNewValue($v_shuffle);
|
||||||
|
|
||||||
$xactions[] = id(clone $template)
|
$xactions[] = id(clone $template)
|
||||||
|
|
|
@ -13,104 +13,12 @@ final class PhabricatorSlowvoteEditor
|
||||||
|
|
||||||
public function getTransactionTypes() {
|
public function getTransactionTypes() {
|
||||||
$types = parent::getTransactionTypes();
|
$types = parent::getTransactionTypes();
|
||||||
|
|
||||||
$types[] = PhabricatorTransactions::TYPE_VIEW_POLICY;
|
$types[] = PhabricatorTransactions::TYPE_VIEW_POLICY;
|
||||||
|
|
||||||
$types[] = PhabricatorSlowvoteTransaction::TYPE_QUESTION;
|
|
||||||
$types[] = PhabricatorSlowvoteTransaction::TYPE_DESCRIPTION;
|
|
||||||
$types[] = PhabricatorSlowvoteTransaction::TYPE_RESPONSES;
|
|
||||||
$types[] = PhabricatorSlowvoteTransaction::TYPE_SHUFFLE;
|
|
||||||
$types[] = PhabricatorSlowvoteTransaction::TYPE_CLOSE;
|
|
||||||
|
|
||||||
return $types;
|
return $types;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function transactionHasEffect(
|
protected function shouldSendMail(
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
$old = $xaction->getOldValue();
|
|
||||||
$new = $xaction->getNewValue();
|
|
||||||
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_RESPONSES:
|
|
||||||
if ($old === null) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return ((int)$old !== (int)$new);
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_SHUFFLE:
|
|
||||||
if ($old === null) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return ((bool)$old !== (bool)$new);
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::transactionHasEffect($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
protected function getCustomTransactionOldValue(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_QUESTION:
|
|
||||||
return $object->getQuestion();
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_DESCRIPTION:
|
|
||||||
return $object->getDescription();
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_RESPONSES:
|
|
||||||
return $object->getResponseVisibility();
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_SHUFFLE:
|
|
||||||
return $object->getShuffle();
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_CLOSE:
|
|
||||||
return $object->getIsClosed();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function getCustomTransactionNewValue(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_QUESTION:
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_DESCRIPTION:
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_RESPONSES:
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_SHUFFLE:
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_CLOSE:
|
|
||||||
return $xaction->getNewValue();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function applyCustomInternalTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_QUESTION:
|
|
||||||
$object->setQuestion($xaction->getNewValue());
|
|
||||||
break;
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_DESCRIPTION:
|
|
||||||
$object->setDescription($xaction->getNewValue());
|
|
||||||
break;
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_RESPONSES:
|
|
||||||
$object->setResponseVisibility($xaction->getNewValue());
|
|
||||||
break;
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_SHUFFLE:
|
|
||||||
$object->setShuffle($xaction->getNewValue());
|
|
||||||
break;
|
|
||||||
case PhabricatorSlowvoteTransaction::TYPE_CLOSE:
|
|
||||||
$object->setIsClosed((int)$xaction->getNewValue());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function applyCustomExternalTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function shouldSendMail(
|
|
||||||
PhabricatorLiskDAO $object,
|
PhabricatorLiskDAO $object,
|
||||||
array $xactions) {
|
array $xactions) {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -21,8 +21,8 @@ final class PhabricatorSlowvotePoll extends PhabricatorSlowvoteDAO
|
||||||
protected $question;
|
protected $question;
|
||||||
protected $description;
|
protected $description;
|
||||||
protected $authorPHID;
|
protected $authorPHID;
|
||||||
protected $responseVisibility;
|
protected $responseVisibility = 0;
|
||||||
protected $shuffle;
|
protected $shuffle = 0;
|
||||||
protected $method;
|
protected $method;
|
||||||
protected $mailKey;
|
protected $mailKey;
|
||||||
protected $viewPolicy;
|
protected $viewPolicy;
|
||||||
|
@ -54,7 +54,7 @@ final class PhabricatorSlowvotePoll extends PhabricatorSlowvoteDAO
|
||||||
self::CONFIG_COLUMN_SCHEMA => array(
|
self::CONFIG_COLUMN_SCHEMA => array(
|
||||||
'question' => 'text255',
|
'question' => 'text255',
|
||||||
'responseVisibility' => 'uint32',
|
'responseVisibility' => 'uint32',
|
||||||
'shuffle' => 'uint32',
|
'shuffle' => 'bool',
|
||||||
'method' => 'uint32',
|
'method' => 'uint32',
|
||||||
'description' => 'text',
|
'description' => 'text',
|
||||||
'isClosed' => 'bool',
|
'isClosed' => 'bool',
|
||||||
|
|
|
@ -1,13 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
final class PhabricatorSlowvoteTransaction
|
final class PhabricatorSlowvoteTransaction
|
||||||
extends PhabricatorApplicationTransaction {
|
extends PhabricatorModularTransaction {
|
||||||
|
|
||||||
const TYPE_QUESTION = 'vote:question';
|
|
||||||
const TYPE_DESCRIPTION = 'vote:description';
|
|
||||||
const TYPE_RESPONSES = 'vote:responses';
|
|
||||||
const TYPE_SHUFFLE = 'vote:shuffle';
|
|
||||||
const TYPE_CLOSE = 'vote:close';
|
|
||||||
|
|
||||||
const MAILTAG_DETAILS = 'vote:details';
|
const MAILTAG_DETAILS = 'vote:details';
|
||||||
const MAILTAG_RESPONSES = 'vote:responses';
|
const MAILTAG_RESPONSES = 'vote:responses';
|
||||||
|
@ -25,237 +19,21 @@ final class PhabricatorSlowvoteTransaction
|
||||||
return new PhabricatorSlowvoteTransactionComment();
|
return new PhabricatorSlowvoteTransactionComment();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function shouldHide() {
|
public function getBaseTransactionClass() {
|
||||||
$old = $this->getOldValue();
|
return 'PhabricatorSlowvoteTransactionType';
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
case self::TYPE_RESPONSES:
|
|
||||||
case self::TYPE_SHUFFLE:
|
|
||||||
case self::TYPE_CLOSE:
|
|
||||||
return ($old === null);
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::shouldHide();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getTitle() {
|
|
||||||
$author_phid = $this->getAuthorPHID();
|
|
||||||
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_QUESTION:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s created this poll.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s changed the poll question from "%s" to "%s".',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return pht(
|
|
||||||
'%s updated the description for this poll.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
case self::TYPE_RESPONSES:
|
|
||||||
// TODO: This could be more detailed
|
|
||||||
return pht(
|
|
||||||
'%s changed who can see the responses.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
case self::TYPE_SHUFFLE:
|
|
||||||
if ($new) {
|
|
||||||
return pht(
|
|
||||||
'%s made poll responses appear in a random order.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s made poll responses appear in a fixed order.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_CLOSE:
|
|
||||||
if ($new) {
|
|
||||||
return pht(
|
|
||||||
'%s closed this poll.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s reopened this poll.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getTitle();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getRemarkupBlocks() {
|
|
||||||
$blocks = parent::getRemarkupBlocks();
|
|
||||||
|
|
||||||
$type = $this->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
$blocks[] = $this->getNewValue();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $blocks;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getTitleForFeed() {
|
|
||||||
$author_phid = $this->getAuthorPHID();
|
|
||||||
$object_phid = $this->getObjectPHID();
|
|
||||||
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
$type = $this->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case self::TYPE_QUESTION:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s created %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s renamed %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the description of %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s edited the description of %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_RESPONSES:
|
|
||||||
// TODO: This could be more detailed
|
|
||||||
return pht(
|
|
||||||
'%s changed who can see the responses of %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
|
|
||||||
case self::TYPE_SHUFFLE:
|
|
||||||
if ($new) {
|
|
||||||
return pht(
|
|
||||||
'%s made %s responses appear in a random order.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s made %s responses appear in a fixed order.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
}
|
|
||||||
case self::TYPE_CLOSE:
|
|
||||||
if ($new) {
|
|
||||||
return pht(
|
|
||||||
'%s closed %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s reopened %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getTitleForFeed();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getIcon() {
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_QUESTION:
|
|
||||||
if ($old === null) {
|
|
||||||
return 'fa-plus';
|
|
||||||
} else {
|
|
||||||
return 'fa-pencil';
|
|
||||||
}
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
case self::TYPE_RESPONSES:
|
|
||||||
return 'fa-pencil';
|
|
||||||
case self::TYPE_SHUFFLE:
|
|
||||||
return 'fa-refresh';
|
|
||||||
case self::TYPE_CLOSE:
|
|
||||||
if ($new) {
|
|
||||||
return 'fa-ban';
|
|
||||||
} else {
|
|
||||||
return 'fa-pencil';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getIcon();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public function getColor() {
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_QUESTION:
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
case self::TYPE_RESPONSES:
|
|
||||||
case self::TYPE_SHUFFLE:
|
|
||||||
case self::TYPE_CLOSE:
|
|
||||||
return PhabricatorTransactions::COLOR_BLUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getColor();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function hasChangeDetails() {
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return parent::hasChangeDetails();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function renderChangeDetails(PhabricatorUser $viewer) {
|
|
||||||
return $this->renderTextCorpusChangeDetails(
|
|
||||||
$viewer,
|
|
||||||
$this->getOldValue(),
|
|
||||||
$this->getNewValue());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getMailTags() {
|
public function getMailTags() {
|
||||||
$tags = parent::getMailTags();
|
$tags = parent::getMailTags();
|
||||||
|
|
||||||
switch ($this->getTransactionType()) {
|
switch ($this->getTransactionType()) {
|
||||||
case self::TYPE_QUESTION:
|
case PhabricatorSlowvoteQuestionTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_DESCRIPTION:
|
case PhabricatorSlowvoteDescriptionTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_SHUFFLE:
|
case PhabricatorSlowvoteShuffleTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_CLOSE:
|
case PhabricatorSlowvoteCloseTransaction::TRANSACTIONTYPE:
|
||||||
$tags[] = self::MAILTAG_DETAILS;
|
$tags[] = self::MAILTAG_DETAILS;
|
||||||
break;
|
break;
|
||||||
case self::TYPE_RESPONSES:
|
case PhabricatorSlowvoteResponsesTransaction::TRANSACTIONTYPE:
|
||||||
$tags[] = self::MAILTAG_RESPONSES;
|
$tags[] = self::MAILTAG_RESPONSES;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -0,0 +1,60 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorSlowvoteCloseTransaction
|
||||||
|
extends PhabricatorSlowvoteTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'vote:close';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return (bool)$object->getIsClosed();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function generateNewValue($object, $value) {
|
||||||
|
return (bool)$value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setIsClosed((int)$value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
|
||||||
|
if ($new) {
|
||||||
|
return pht(
|
||||||
|
'%s closed this poll.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s reopened this poll.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
|
||||||
|
if ($new) {
|
||||||
|
return pht(
|
||||||
|
'%s closed %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s reopened %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
|
||||||
|
if ($new) {
|
||||||
|
return 'fa-ban';
|
||||||
|
} else {
|
||||||
|
return 'fa-pencil';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorSlowvoteDescriptionTransaction
|
||||||
|
extends PhabricatorSlowvoteTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'vote:description';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getDescription();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setDescription($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s updated the description for this poll.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$old = $this->getOldValue();
|
||||||
|
|
||||||
|
if ($old === null) {
|
||||||
|
return pht(
|
||||||
|
'%s set the description of %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s edited the description of %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function hasChangeDetails() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newChangeDetailView() {
|
||||||
|
return $this->renderTextCorpusChangeDetails(
|
||||||
|
$this->getViewer(),
|
||||||
|
$this->getOldValue(),
|
||||||
|
$this->getNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newRemarkupChanges() {
|
||||||
|
$changes = array();
|
||||||
|
|
||||||
|
$changes[] = $this->newRemarkupChange()
|
||||||
|
->setOldValue($this->getOldValue())
|
||||||
|
->setNewValue($this->getNewValue());
|
||||||
|
|
||||||
|
return $changes;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,70 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorSlowvoteQuestionTransaction
|
||||||
|
extends PhabricatorSlowvoteTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'vote:question';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getQuestion();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setQuestion($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
$old = $this->getOldValue();
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
|
||||||
|
if ($old === null) {
|
||||||
|
return pht(
|
||||||
|
'%s created this poll.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s changed the poll question from "%s" to "%s".',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$old,
|
||||||
|
$new);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$old = $this->getOldValue();
|
||||||
|
|
||||||
|
if ($old === null) {
|
||||||
|
return pht(
|
||||||
|
'%s created %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s renamed %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
$old = $this->getOldValue();
|
||||||
|
|
||||||
|
if ($old === null) {
|
||||||
|
return 'fa-plus';
|
||||||
|
} else {
|
||||||
|
return 'fa-pencil';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
if ($this->isEmptyTextTransaction($object->getQuestion(), $xactions)) {
|
||||||
|
$errors[] = $this->newRequiredError(pht('Polls must have a question.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,31 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorSlowvoteResponsesTransaction
|
||||||
|
extends PhabricatorSlowvoteTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'vote:responses';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return (int)$object->getResponseVisibility();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setResponseVisibility($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
// TODO: This could be more detailed
|
||||||
|
return pht(
|
||||||
|
'%s changed who can see the responses.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
// TODO: This could be more detailed
|
||||||
|
return pht(
|
||||||
|
'%s changed who can see the responses of %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,55 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorSlowvoteShuffleTransaction
|
||||||
|
extends PhabricatorSlowvoteTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'vote:shuffle';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return (bool)$object->getShuffle();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function generateNewValue($object, $value) {
|
||||||
|
return (bool)$value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setShuffle((int)$value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
|
||||||
|
if ($new) {
|
||||||
|
return pht(
|
||||||
|
'%s made poll responses appear in a random order.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s made poll responses appear in a fixed order.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
|
||||||
|
if ($new) {
|
||||||
|
return pht(
|
||||||
|
'%s made %s responses appear in a random order.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s made %s responses appear in a fixed order.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return 'fa-refresh';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,4 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
abstract class PhabricatorSlowvoteTransactionType
|
||||||
|
extends PhabricatorModularTransactionType {}
|
Loading…
Add table
Reference in a new issue