mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-05 04:11:01 +01:00
Stop reads and writes to projectPHIDs property on ManiphestTask
Summary: Ref T5245. This property predates edges and is unusual in modern applications. Stop writes to it and populate it implicitly from edges when querying. Test Plan: - Viewed task list. - Created a task. - Added and removed projects from tasks. Reviewers: joshuaspence, chad, btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T5245 Differential Revision: https://secure.phabricator.com/D9851
This commit is contained in:
parent
aa79539789
commit
b8b59895ee
5 changed files with 39 additions and 14 deletions
|
@ -81,7 +81,7 @@ final class ManiphestTaskEditController extends ManiphestController {
|
||||||
$default_projects = mpull($default_projects, 'getPHID');
|
$default_projects = mpull($default_projects, 'getPHID');
|
||||||
|
|
||||||
if ($default_projects) {
|
if ($default_projects) {
|
||||||
$task->setProjectPHIDs($default_projects);
|
$task->attachProjectPHIDs($default_projects);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -215,7 +215,7 @@ final class ManiphestTaskEditController extends ManiphestController {
|
||||||
$task->setPriority($request->getInt('priority'));
|
$task->setPriority($request->getInt('priority'));
|
||||||
$task->setOwnerPHID($owner_phid);
|
$task->setOwnerPHID($owner_phid);
|
||||||
$task->setCCPHIDs($request->getArr('cc'));
|
$task->setCCPHIDs($request->getArr('cc'));
|
||||||
$task->setProjectPHIDs($request->getArr('projects'));
|
$task->attachProjectPHIDs($request->getArr('projects'));
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
if ($can_edit_priority) {
|
if ($can_edit_priority) {
|
||||||
|
@ -438,7 +438,7 @@ final class ManiphestTaskEditController extends ManiphestController {
|
||||||
->executeOne();
|
->executeOne();
|
||||||
if ($template_task) {
|
if ($template_task) {
|
||||||
$task->setCCPHIDs($template_task->getCCPHIDs());
|
$task->setCCPHIDs($template_task->getCCPHIDs());
|
||||||
$task->setProjectPHIDs($template_task->getProjectPHIDs());
|
$task->attachProjectPHIDs($template_task->getProjectPHIDs());
|
||||||
$task->setOwnerPHID($template_task->getOwnerPHID());
|
$task->setOwnerPHID($template_task->getOwnerPHID());
|
||||||
$task->setPriority($template_task->getPriority());
|
$task->setPriority($template_task->getPriority());
|
||||||
$task->setViewPolicy($template_task->getViewPolicy());
|
$task->setViewPolicy($template_task->getViewPolicy());
|
||||||
|
|
|
@ -150,8 +150,9 @@ final class ManiphestTransactionEditor
|
||||||
case ManiphestTransaction::TYPE_CCS:
|
case ManiphestTransaction::TYPE_CCS:
|
||||||
return $object->setCCPHIDs($xaction->getNewValue());
|
return $object->setCCPHIDs($xaction->getNewValue());
|
||||||
case ManiphestTransaction::TYPE_PROJECTS:
|
case ManiphestTransaction::TYPE_PROJECTS:
|
||||||
$object->setProjectPHIDs($xaction->getNewValue());
|
ManiphestTaskProject::updateTaskProjects(
|
||||||
ManiphestTaskProject::updateTaskProjects($object);
|
$object,
|
||||||
|
$xaction->getNewValue());
|
||||||
return $object;
|
return $object;
|
||||||
case ManiphestTransaction::TYPE_SUBPRIORITY:
|
case ManiphestTransaction::TYPE_SUBPRIORITY:
|
||||||
$data = $xaction->getNewValue();
|
$data = $xaction->getNewValue();
|
||||||
|
|
|
@ -331,6 +331,27 @@ final class ManiphestTaskQuery extends PhabricatorCursorPagedPolicyAwareQuery {
|
||||||
return $tasks;
|
return $tasks;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function didFilterPage(array $tasks) {
|
||||||
|
// TODO: Eventually, we should make this optional and introduce a
|
||||||
|
// needProjectPHIDs() method, but for now there's a lot of code which
|
||||||
|
// assumes the data is always populated.
|
||||||
|
|
||||||
|
$edge_query = id(new PhabricatorEdgeQuery())
|
||||||
|
->withSourcePHIDs(mpull($tasks, 'getPHID'))
|
||||||
|
->withEdgeTypes(
|
||||||
|
array(
|
||||||
|
PhabricatorProjectObjectHasProjectEdgeType::EDGECONST,
|
||||||
|
));
|
||||||
|
$edge_query->execute();
|
||||||
|
|
||||||
|
foreach ($tasks as $task) {
|
||||||
|
$phids = $edge_query->getDestinationPHIDs(array($task->getPHID()));
|
||||||
|
$task->attachProjectPHIDs($phids);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $tasks;
|
||||||
|
}
|
||||||
|
|
||||||
private function buildTaskIDsWhereClause(AphrontDatabaseConnection $conn) {
|
private function buildTaskIDsWhereClause(AphrontDatabaseConnection $conn) {
|
||||||
if (!$this->taskIDs) {
|
if (!$this->taskIDs) {
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -37,6 +37,7 @@ final class ManiphestTask extends ManiphestDAO
|
||||||
|
|
||||||
private $groupByProjectPHID = self::ATTACHABLE;
|
private $groupByProjectPHID = self::ATTACHABLE;
|
||||||
private $customFields = self::ATTACHABLE;
|
private $customFields = self::ATTACHABLE;
|
||||||
|
private $edgeProjectPHIDs = self::ATTACHABLE;
|
||||||
|
|
||||||
public static function initializeNewTask(PhabricatorUser $actor) {
|
public static function initializeNewTask(PhabricatorUser $actor) {
|
||||||
$app = id(new PhabricatorApplicationQuery())
|
$app = id(new PhabricatorApplicationQuery())
|
||||||
|
@ -52,7 +53,8 @@ final class ManiphestTask extends ManiphestDAO
|
||||||
->setPriority(ManiphestTaskPriority::getDefaultPriority())
|
->setPriority(ManiphestTaskPriority::getDefaultPriority())
|
||||||
->setAuthorPHID($actor->getPHID())
|
->setAuthorPHID($actor->getPHID())
|
||||||
->setViewPolicy($view_policy)
|
->setViewPolicy($view_policy)
|
||||||
->setEditPolicy($edit_policy);
|
->setEditPolicy($edit_policy)
|
||||||
|
->attachProjectPHIDs(array());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getConfiguration() {
|
public function getConfiguration() {
|
||||||
|
@ -90,13 +92,13 @@ final class ManiphestTask extends ManiphestDAO
|
||||||
return array_values(nonempty($this->ccPHIDs, array()));
|
return array_values(nonempty($this->ccPHIDs, array()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setProjectPHIDs(array $phids) {
|
public function getProjectPHIDs() {
|
||||||
$this->projectPHIDs = array_values($phids);
|
return $this->assertAttached($this->edgeProjectPHIDs);
|
||||||
return $this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getProjectPHIDs() {
|
public function attachProjectPHIDs(array $phids) {
|
||||||
return array_values(nonempty($this->projectPHIDs, array()));
|
$this->edgeProjectPHIDs = $phids;
|
||||||
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function setCCPHIDs(array $phids) {
|
public function setCCPHIDs(array $phids) {
|
||||||
|
|
|
@ -19,13 +19,15 @@ final class ManiphestTaskProject extends ManiphestDAO {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function updateTaskProjects(ManiphestTask $task) {
|
public static function updateTaskProjects(
|
||||||
|
ManiphestTask $task,
|
||||||
|
array $new_phids) {
|
||||||
|
|
||||||
$edge_type = PhabricatorProjectObjectHasProjectEdgeType::EDGECONST;
|
$edge_type = PhabricatorProjectObjectHasProjectEdgeType::EDGECONST;
|
||||||
|
|
||||||
$old_phids = PhabricatorEdgeQuery::loadDestinationPHIDs(
|
$old_phids = PhabricatorEdgeQuery::loadDestinationPHIDs(
|
||||||
$task->getPHID(),
|
$task->getPHID(),
|
||||||
$edge_type);
|
$edge_type);
|
||||||
$new_phids = $task->getProjectPHIDs();
|
|
||||||
|
|
||||||
$add_phids = array_diff($new_phids, $old_phids);
|
$add_phids = array_diff($new_phids, $old_phids);
|
||||||
$rem_phids = array_diff($old_phids, $new_phids);
|
$rem_phids = array_diff($old_phids, $new_phids);
|
||||||
|
@ -34,7 +36,6 @@ final class ManiphestTaskProject extends ManiphestDAO {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
$editor = new PhabricatorEdgeEditor();
|
$editor = new PhabricatorEdgeEditor();
|
||||||
foreach ($add_phids as $phid) {
|
foreach ($add_phids as $phid) {
|
||||||
$editor->addEdge($task->getPHID(), $edge_type, $phid);
|
$editor->addEdge($task->getPHID(), $edge_type, $phid);
|
||||||
|
|
Loading…
Reference in a new issue