mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-02 19:01:03 +01:00
Use application handle infrastructure for Releeph Requests and Releeph Projects
Summary: Ref T2715. Test Plan: Used `phid.query` to query handles. Browsed Releeph. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T2715 Differential Revision: https://secure.phabricator.com/D6510
This commit is contained in:
parent
1fb39a20d3
commit
f2ed56147d
9 changed files with 128 additions and 54 deletions
|
@ -1903,6 +1903,8 @@ phutil_register_library_map(array(
|
||||||
'ReleephObjectHandleLoader' => 'applications/releeph/ReleephObjectHandleLoader.php',
|
'ReleephObjectHandleLoader' => 'applications/releeph/ReleephObjectHandleLoader.php',
|
||||||
'ReleephOriginalCommitFieldSpecification' => 'applications/releeph/field/specification/ReleephOriginalCommitFieldSpecification.php',
|
'ReleephOriginalCommitFieldSpecification' => 'applications/releeph/field/specification/ReleephOriginalCommitFieldSpecification.php',
|
||||||
'ReleephPHIDConstants' => 'applications/releeph/ReleephPHIDConstants.php',
|
'ReleephPHIDConstants' => 'applications/releeph/ReleephPHIDConstants.php',
|
||||||
|
'ReleephPHIDTypeProject' => 'applications/releeph/phid/ReleephPHIDTypeProject.php',
|
||||||
|
'ReleephPHIDTypeRequest' => 'applications/releeph/phid/ReleephPHIDTypeRequest.php',
|
||||||
'ReleephProject' => 'applications/releeph/storage/ReleephProject.php',
|
'ReleephProject' => 'applications/releeph/storage/ReleephProject.php',
|
||||||
'ReleephProjectActionController' => 'applications/releeph/controller/project/ReleephProjectActionController.php',
|
'ReleephProjectActionController' => 'applications/releeph/controller/project/ReleephProjectActionController.php',
|
||||||
'ReleephProjectController' => 'applications/releeph/controller/ReleephProjectController.php',
|
'ReleephProjectController' => 'applications/releeph/controller/ReleephProjectController.php',
|
||||||
|
@ -3943,6 +3945,8 @@ phutil_register_library_map(array(
|
||||||
'ReleephLevelFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephLevelFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
'ReleephObjectHandleLoader' => 'ObjectHandleLoader',
|
'ReleephObjectHandleLoader' => 'ObjectHandleLoader',
|
||||||
'ReleephOriginalCommitFieldSpecification' => 'ReleephFieldSpecification',
|
'ReleephOriginalCommitFieldSpecification' => 'ReleephFieldSpecification',
|
||||||
|
'ReleephPHIDTypeProject' => 'PhabricatorPHIDType',
|
||||||
|
'ReleephPHIDTypeRequest' => 'PhabricatorPHIDType',
|
||||||
'ReleephProject' =>
|
'ReleephProject' =>
|
||||||
array(
|
array(
|
||||||
0 => 'ReleephDAO',
|
0 => 'ReleephDAO',
|
||||||
|
|
|
@ -2,14 +2,6 @@
|
||||||
|
|
||||||
final class ReleephObjectHandleLoader extends ObjectHandleLoader {
|
final class ReleephObjectHandleLoader extends ObjectHandleLoader {
|
||||||
|
|
||||||
/**
|
|
||||||
* The intention for phid.external-loaders is for each new 4-char PHID type
|
|
||||||
* to point to a different external loader for that type.
|
|
||||||
*
|
|
||||||
* For brevity, we instead just have this one class that can load any type of
|
|
||||||
* Releeph PHID.
|
|
||||||
*/
|
|
||||||
|
|
||||||
public function loadHandles(array $phids) {
|
public function loadHandles(array $phids) {
|
||||||
$types = array();
|
$types = array();
|
||||||
|
|
||||||
|
@ -22,27 +14,6 @@ final class ReleephObjectHandleLoader extends ObjectHandleLoader {
|
||||||
|
|
||||||
foreach ($types as $type => $phids) {
|
foreach ($types as $type => $phids) {
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
case ReleephPHIDConstants::PHID_TYPE_RERQ:
|
|
||||||
$object = new ReleephRequest();
|
|
||||||
|
|
||||||
$instances = $object->loadAllWhere('phid in (%Ls)', $phids);
|
|
||||||
$instances = mpull($instances, null, 'getPHID');
|
|
||||||
|
|
||||||
foreach ($phids as $phid) {
|
|
||||||
$instance = $instances[$phid];
|
|
||||||
$handle = new PhabricatorObjectHandle();
|
|
||||||
$handle->setPHID($phid);
|
|
||||||
$handle->setType($type);
|
|
||||||
$handle->setURI('/RQ'.$instance->getID());
|
|
||||||
|
|
||||||
$name = 'RQ'.$instance->getID();
|
|
||||||
$handle->setName($name);
|
|
||||||
$handle->setFullName($name.': '.$instance->getSummaryForDisplay());
|
|
||||||
$handle->setComplete(true);
|
|
||||||
|
|
||||||
$handles[$phid] = $handle;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ReleephPHIDConstants::PHID_TYPE_REBR:
|
case ReleephPHIDConstants::PHID_TYPE_REBR:
|
||||||
$object = new ReleephBranch();
|
$object = new ReleephBranch();
|
||||||
|
@ -63,24 +34,6 @@ final class ReleephObjectHandleLoader extends ObjectHandleLoader {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ReleephPHIDConstants::PHID_TYPE_REPR:
|
|
||||||
$object = new ReleephProject();
|
|
||||||
|
|
||||||
$instances = $object->loadAllWhere('phid IN (%Ls)', $phids);
|
|
||||||
$instances = mpull($instances, null, 'getPHID');
|
|
||||||
|
|
||||||
foreach ($phids as $phid) {
|
|
||||||
$instance = $instances[$phid];
|
|
||||||
$handle = new PhabricatorObjectHandle();
|
|
||||||
$handle->setPHID($phid);
|
|
||||||
$handle->setType($type);
|
|
||||||
$handle->setURI($instance->getURI());
|
|
||||||
$handle->setName($instance->getName()); // no fullName for proejcts
|
|
||||||
$handle->setComplete(true);
|
|
||||||
$handles[$phid] = $handle;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
throw new Exception('unknown type '.$type);
|
throw new Exception('unknown type '.$type);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
final class ReleephPHIDConstants {
|
final class ReleephPHIDConstants {
|
||||||
|
|
||||||
// Releeph
|
|
||||||
const PHID_TYPE_REPR = 'REPR';
|
|
||||||
const PHID_TYPE_REBR = 'REBR';
|
const PHID_TYPE_REBR = 'REBR';
|
||||||
const PHID_TYPE_RERQ = 'RERQ';
|
|
||||||
}
|
}
|
||||||
|
|
46
src/applications/releeph/phid/ReleephPHIDTypeProject.php
Normal file
46
src/applications/releeph/phid/ReleephPHIDTypeProject.php
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class ReleephPHIDTypeProject extends PhabricatorPHIDType {
|
||||||
|
|
||||||
|
const TYPECONST = 'REPR';
|
||||||
|
|
||||||
|
public function getTypeConstant() {
|
||||||
|
return self::TYPECONST;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTypeName() {
|
||||||
|
return pht('Releeph Project');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newObject() {
|
||||||
|
return new ReleephProject();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function loadObjects(
|
||||||
|
PhabricatorObjectQuery $query,
|
||||||
|
array $phids) {
|
||||||
|
|
||||||
|
return id(new ReleephProjectQuery())
|
||||||
|
->setViewer($query->getViewer())
|
||||||
|
->withPHIDs($phids)
|
||||||
|
->execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function loadHandles(
|
||||||
|
PhabricatorHandleQuery $query,
|
||||||
|
array $handles,
|
||||||
|
array $objects) {
|
||||||
|
|
||||||
|
foreach ($handles as $phid => $handle) {
|
||||||
|
$project = $objects[$phid];
|
||||||
|
|
||||||
|
$handle->setName($project->getName());
|
||||||
|
$handle->setURI($project->getURI());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function canLoadNamedObject($name) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
50
src/applications/releeph/phid/ReleephPHIDTypeRequest.php
Normal file
50
src/applications/releeph/phid/ReleephPHIDTypeRequest.php
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class ReleephPHIDTypeRequest extends PhabricatorPHIDType {
|
||||||
|
|
||||||
|
const TYPECONST = 'RERQ';
|
||||||
|
|
||||||
|
public function getTypeConstant() {
|
||||||
|
return self::TYPECONST;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTypeName() {
|
||||||
|
return pht('Releeph Request');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newObject() {
|
||||||
|
return new ReleephRequest();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function loadObjects(
|
||||||
|
PhabricatorObjectQuery $query,
|
||||||
|
array $phids) {
|
||||||
|
|
||||||
|
return id(new ReleephRequestQuery())
|
||||||
|
->setViewer($query->getViewer())
|
||||||
|
->withPHIDs($phids)
|
||||||
|
->execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function loadHandles(
|
||||||
|
PhabricatorHandleQuery $query,
|
||||||
|
array $handles,
|
||||||
|
array $objects) {
|
||||||
|
|
||||||
|
foreach ($handles as $phid => $handle) {
|
||||||
|
$request = $objects[$phid];
|
||||||
|
|
||||||
|
$id = $request->getID();
|
||||||
|
$title = $request->getSummaryForDisplay();
|
||||||
|
|
||||||
|
$handle->setURI("/RQ{$id}");
|
||||||
|
$handle->setName($title);
|
||||||
|
$handle->setFullName("RQ{$id}: {$title}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function canLoadNamedObject($name) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -4,6 +4,7 @@ final class ReleephProjectQuery
|
||||||
extends PhabricatorCursorPagedPolicyAwareQuery {
|
extends PhabricatorCursorPagedPolicyAwareQuery {
|
||||||
|
|
||||||
private $active;
|
private $active;
|
||||||
|
private $phids;
|
||||||
|
|
||||||
private $order = 'order-id';
|
private $order = 'order-id';
|
||||||
const ORDER_ID = 'order-id';
|
const ORDER_ID = 'order-id';
|
||||||
|
@ -19,6 +20,11 @@ final class ReleephProjectQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function withPHIDs(array $phids) {
|
||||||
|
$this->phids = $phids;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function loadPage() {
|
public function loadPage() {
|
||||||
$table = new ReleephProject();
|
$table = new ReleephProject();
|
||||||
$conn_r = $table->establishConnection('r');
|
$conn_r = $table->establishConnection('r');
|
||||||
|
@ -44,6 +50,13 @@ final class ReleephProjectQuery
|
||||||
$this->active);
|
$this->active);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->phids) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'phid IN (%Ls)',
|
||||||
|
$this->phids);
|
||||||
|
}
|
||||||
|
|
||||||
$where[] = $this->buildPagingClause($conn_r);
|
$where[] = $this->buildPagingClause($conn_r);
|
||||||
|
|
||||||
return $this->formatWhereClause($where);
|
return $this->formatWhereClause($where);
|
||||||
|
|
|
@ -6,12 +6,18 @@ final class ReleephRequestQuery
|
||||||
private $requestedCommitPHIDs;
|
private $requestedCommitPHIDs;
|
||||||
private $commitToRevMap;
|
private $commitToRevMap;
|
||||||
private $ids;
|
private $ids;
|
||||||
|
private $phids;
|
||||||
|
|
||||||
public function withIDs(array $ids) {
|
public function withIDs(array $ids) {
|
||||||
$this->ids = $ids;
|
$this->ids = $ids;
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function withPHIDs(array $phids) {
|
||||||
|
$this->phids = $phids;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function getRevisionPHID($commit_phid) {
|
public function getRevisionPHID($commit_phid) {
|
||||||
if ($this->commitToRevMap) {
|
if ($this->commitToRevMap) {
|
||||||
return idx($this->commitToRevMap, $commit_phid, null);
|
return idx($this->commitToRevMap, $commit_phid, null);
|
||||||
|
@ -69,6 +75,13 @@ final class ReleephRequestQuery
|
||||||
$this->ids);
|
$this->ids);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->phids) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'phid IN (%Ls)',
|
||||||
|
$this->phids);
|
||||||
|
}
|
||||||
|
|
||||||
if ($this->requestedCommitPHIDs) {
|
if ($this->requestedCommitPHIDs) {
|
||||||
$where[] = qsprintf(
|
$where[] = qsprintf(
|
||||||
$conn_r,
|
$conn_r,
|
||||||
|
|
|
@ -37,8 +37,7 @@ final class ReleephProject extends ReleephDAO
|
||||||
}
|
}
|
||||||
|
|
||||||
public function generatePHID() {
|
public function generatePHID() {
|
||||||
return PhabricatorPHID::generateNewPHID(
|
return PhabricatorPHID::generateNewPHID(ReleephPHIDTypeProject::TYPECONST);
|
||||||
ReleephPHIDConstants::PHID_TYPE_REPR);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDetail($key, $default = null) {
|
public function getDetail($key, $default = null) {
|
||||||
|
|
|
@ -16,7 +16,7 @@ final class ReleephRequestTransaction
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationTransactionType() {
|
public function getApplicationTransactionType() {
|
||||||
return ReleephPHIDConstants::PHID_TYPE_RERQ;
|
return ReleephPHIDTypeRequest::TYPECONST;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationTransactionCommentObject() {
|
public function getApplicationTransactionCommentObject() {
|
||||||
|
|
Loading…
Reference in a new issue