1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-04 11:51:02 +01:00

Use application PHIDs in Pholio Mocks

Summary: Ref T2715. Switch mocks to the new stuff.

Test Plan: Used `phid.query` and `phid.lookup` to find mocks.

Reviewers: btrahan

Reviewed By: btrahan

CC: aran

Maniphest Tasks: T2715

Differential Revision: https://secure.phabricator.com/D6517
This commit is contained in:
epriestley 2013-07-21 12:40:51 -07:00
parent 17ee71d896
commit 2ff57f6938
11 changed files with 86 additions and 45 deletions

View file

@ -1746,6 +1746,7 @@ phutil_register_library_map(array(
'PholioMockMailReceiver' => 'applications/pholio/mail/PholioMockMailReceiver.php', 'PholioMockMailReceiver' => 'applications/pholio/mail/PholioMockMailReceiver.php',
'PholioMockQuery' => 'applications/pholio/query/PholioMockQuery.php', 'PholioMockQuery' => 'applications/pholio/query/PholioMockQuery.php',
'PholioMockViewController' => 'applications/pholio/controller/PholioMockViewController.php', 'PholioMockViewController' => 'applications/pholio/controller/PholioMockViewController.php',
'PholioPHIDTypeMock' => 'applications/pholio/phid/PholioPHIDTypeMock.php',
'PholioRemarkupRule' => 'applications/pholio/remarkup/PholioRemarkupRule.php', 'PholioRemarkupRule' => 'applications/pholio/remarkup/PholioRemarkupRule.php',
'PholioReplyHandler' => 'applications/pholio/mail/PholioReplyHandler.php', 'PholioReplyHandler' => 'applications/pholio/mail/PholioReplyHandler.php',
'PholioSearchIndexer' => 'applications/pholio/search/PholioSearchIndexer.php', 'PholioSearchIndexer' => 'applications/pholio/search/PholioSearchIndexer.php',
@ -3769,6 +3770,7 @@ phutil_register_library_map(array(
'PholioMockMailReceiver' => 'PhabricatorObjectMailReceiver', 'PholioMockMailReceiver' => 'PhabricatorObjectMailReceiver',
'PholioMockQuery' => 'PhabricatorCursorPagedPolicyAwareQuery', 'PholioMockQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
'PholioMockViewController' => 'PholioController', 'PholioMockViewController' => 'PholioController',
'PholioPHIDTypeMock' => 'PhabricatorPHIDType',
'PholioRemarkupRule' => 'PhabricatorRemarkupRuleObject', 'PholioRemarkupRule' => 'PhabricatorRemarkupRuleObject',
'PholioReplyHandler' => 'PhabricatorMailReplyHandler', 'PholioReplyHandler' => 'PhabricatorMailReplyHandler',
'PholioSearchIndexer' => 'PhabricatorSearchDocumentIndexer', 'PholioSearchIndexer' => 'PhabricatorSearchDocumentIndexer',

View file

@ -111,7 +111,6 @@ final class PhabricatorObjectHandle
PhabricatorPHIDConstants::PHID_TYPE_USER => 'User', PhabricatorPHIDConstants::PHID_TYPE_USER => 'User',
PhabricatorPHIDConstants::PHID_TYPE_WIKI => 'Phriction Document', PhabricatorPHIDConstants::PHID_TYPE_WIKI => 'Phriction Document',
PhabricatorPHIDConstants::PHID_TYPE_MCRO => 'Image Macro', PhabricatorPHIDConstants::PHID_TYPE_MCRO => 'Image Macro',
PhabricatorPHIDConstants::PHID_TYPE_MOCK => 'Pholio Mock',
PhabricatorPHIDConstants::PHID_TYPE_PIMG => 'Pholio Image', PhabricatorPHIDConstants::PHID_TYPE_PIMG => 'Pholio Image',
PhabricatorPHIDConstants::PHID_TYPE_FILE => 'File', PhabricatorPHIDConstants::PHID_TYPE_FILE => 'File',
PhabricatorPHIDConstants::PHID_TYPE_BLOG => 'Blog', PhabricatorPHIDConstants::PHID_TYPE_BLOG => 'Blog',

View file

@ -23,7 +23,6 @@ final class PhabricatorPHIDConstants {
const PHID_TYPE_BLOG = 'BLOG'; const PHID_TYPE_BLOG = 'BLOG';
const PHID_TYPE_QUES = 'QUES'; const PHID_TYPE_QUES = 'QUES';
const PHID_TYPE_ANSW = 'ANSW'; const PHID_TYPE_ANSW = 'ANSW';
const PHID_TYPE_MOCK = 'MOCK';
const PHID_TYPE_PIMG = 'PIMG'; const PHID_TYPE_PIMG = 'PIMG';
const PHID_TYPE_MCRO = 'MCRO'; const PHID_TYPE_MCRO = 'MCRO';
const PHID_TYPE_CONF = 'CONF'; const PHID_TYPE_CONF = 'CONF';

View file

@ -110,13 +110,6 @@ final class PhabricatorObjectHandleData {
->execute(); ->execute();
return mpull($questions, null, 'getPHID'); return mpull($questions, null, 'getPHID');
case PhabricatorPHIDConstants::PHID_TYPE_MOCK:
$mocks = id(new PholioMockQuery())
->setViewer($this->viewer)
->withPHIDs($phids)
->execute();
return mpull($mocks, null, 'getPHID');
case PhabricatorPHIDConstants::PHID_TYPE_PIMG: case PhabricatorPHIDConstants::PHID_TYPE_PIMG:
$images = id(new PholioImage()) $images = id(new PholioImage())
->loadAllWhere('phid IN (%Ls)', $phids); ->loadAllWhere('phid IN (%Ls)', $phids);
@ -131,7 +124,7 @@ final class PhabricatorObjectHandleData {
foreach ($subtypes as $subtype => $subtype_phids) { foreach ($subtypes as $subtype => $subtype_phids) {
// TODO: Do this magically. // TODO: Do this magically.
switch ($subtype) { switch ($subtype) {
case PhabricatorPHIDConstants::PHID_TYPE_MOCK: case PholioPHIDTypeMock::TYPECONST:
$results = id(new PholioTransactionQuery()) $results = id(new PholioTransactionQuery())
->setViewer($this->viewer) ->setViewer($this->viewer)
->withPHIDs($subtype_phids) ->withPHIDs($subtype_phids)
@ -524,24 +517,6 @@ final class PhabricatorObjectHandleData {
} }
break; break;
case PhabricatorPHIDConstants::PHID_TYPE_MOCK:
foreach ($phids as $phid) {
$handle = new PhabricatorObjectHandle();
$handle->setPHID($phid);
$handle->setType($type);
if (empty($objects[$phid])) {
$handle->setName('Unknown Mock');
} else {
$mock = $objects[$phid];
$handle->setName('M'.$mock->getID());
$handle->setFullName('M'.$mock->getID().': '.$mock->getName());
$handle->setURI('/M'.$mock->getID());
$handle->setComplete(true);
}
$handles[$phid] = $handle;
}
break;
case PhabricatorPHIDConstants::PHID_TYPE_PIMG: case PhabricatorPHIDConstants::PHID_TYPE_PIMG:
foreach ($phids as $phid) { foreach ($phids as $phid) {
$handle = new PhabricatorObjectHandle(); $handle = new PhabricatorObjectHandle();

View file

@ -44,14 +44,6 @@ final class PhabricatorPHID {
return $name; return $name;
} }
if (preg_match('/^m(\d+)$/i', $name, $match)) {
$objects = id(new PholioMockQuery())
->setViewer($viewer)
->withIDs(array($match[1]))
->execute();
$object = head($objects);
}
if ($object) { if ($object) {
return $object->getPHID(); return $object->getPHID();
} }

View file

@ -0,0 +1,75 @@
<?php
final class PholioPHIDTypeMock extends PhabricatorPHIDType {
const TYPECONST = 'MOCK';
public function getTypeConstant() {
return self::TYPECONST;
}
public function getTypeName() {
return pht('Mock');
}
public function newObject() {
return new PholioMock();
}
public function loadObjects(
PhabricatorObjectQuery $query,
array $phids) {
return id(new PholioMockQuery())
->setViewer($query->getViewer())
->withPHIDs($phids)
->execute();
}
public function loadHandles(
PhabricatorHandleQuery $query,
array $handles,
array $objects) {
foreach ($handles as $phid => $handle) {
$mock = $objects[$phid];
$id = $mock->getID();
$name = $mock->getName();
$handle->setURI("/M{$id}");
$handle->setName("M{$id}");
$handle->setFullName("M{$id}: {$name}");
}
}
public function canLoadNamedObject($name) {
return preg_match('/^M\d*[1-9]\d*$/i', $name);
}
public function loadNamedObjects(
PhabricatorObjectQuery $query,
array $names) {
$id_map = array();
foreach ($names as $name) {
$id = (int)substr($name, 1);
$id_map[$id][] = $name;
}
$objects = id(new PholioMockQuery())
->setViewer($query->getViewer())
->withIDs(array_keys($id_map))
->execute();
$results = array();
foreach ($objects as $id => $object) {
foreach (idx($id_map, $id, array()) as $name) {
$results[$name] = $object;
}
}
return $results;
}
}

View file

@ -10,7 +10,7 @@ final class PholioTransaction extends PhabricatorApplicationTransaction {
} }
public function getApplicationTransactionType() { public function getApplicationTransactionType() {
return PhabricatorPHIDConstants::PHID_TYPE_MOCK; return PholioPHIDTypeMock::TYPECONST;
} }
public function getApplicationTransactionCommentObject() { public function getApplicationTransactionCommentObject() {

View file

@ -210,7 +210,7 @@ final class PhabricatorSearchAttachController
$noun = 'Commits'; $noun = 'Commits';
$selected = 'created'; $selected = 'created';
break; break;
case PhabricatorPHIDConstants::PHID_TYPE_MOCK: case PholioPHIDTypeMock::TYPECONST:
$noun = 'Mocks'; $noun = 'Mocks';
$selected = 'created'; $selected = 'created';
break; break;
@ -251,7 +251,7 @@ final class PhabricatorSearchAttachController
} }
private function getFilters(array $strings) { private function getFilters(array $strings) {
if ($this->type == PhabricatorPHIDConstants::PHID_TYPE_MOCK) { if ($this->type == PholioPHIDTypeMock::TYPECONST) {
$filters = array( $filters = array(
'created' => 'Created By Me', 'created' => 'Created By Me',
'all' => 'All '.$strings['target_plural_noun'], 'all' => 'All '.$strings['target_plural_noun'],
@ -272,7 +272,7 @@ final class PhabricatorSearchAttachController
$t_cmit = PhabricatorRepositoryPHIDTypeCommit::TYPECONST; $t_cmit = PhabricatorRepositoryPHIDTypeCommit::TYPECONST;
$t_task = ManiphestPHIDTypeTask::TYPECONST; $t_task = ManiphestPHIDTypeTask::TYPECONST;
$t_drev = DifferentialPHIDTypeRevision::TYPECONST; $t_drev = DifferentialPHIDTypeRevision::TYPECONST;
$t_mock = PhabricatorPHIDConstants::PHID_TYPE_MOCK; $t_mock = PholioPHIDTypeMock::TYPECONST;
$map = array( $map = array(
$t_cmit => array( $t_cmit => array(

View file

@ -33,7 +33,7 @@ final class PhabricatorSearchSelectController
$query->setParameter('author', array($user->getPHID())); $query->setParameter('author', array($user->getPHID()));
// TODO - if / when we allow pholio mocks to be archived, etc // TODO - if / when we allow pholio mocks to be archived, etc
// update this // update this
if ($this->type != PhabricatorPHIDConstants::PHID_TYPE_MOCK) { if ($this->type != PholioPHIDTypeMock::TYPECONST) {
$query->setParameter('open', 1); $query->setParameter('open', 1);
} }
break; break;
@ -73,7 +73,7 @@ final class PhabricatorSearchSelectController
case DifferentialPHIDTypeRevision::TYPECONST: case DifferentialPHIDTypeRevision::TYPECONST:
$pattern = '/\bD(\d+)\b/i'; $pattern = '/\bD(\d+)\b/i';
break; break;
case PhabricatorPHIDConstants::PHID_TYPE_MOCK: case PholioPHIDTypeMock::TYPECONST:
$pattern = '/\bM(\d+)\b/i'; $pattern = '/\bM(\d+)\b/i';
break; break;
} }
@ -104,7 +104,7 @@ final class PhabricatorSearchSelectController
'id IN (%Ld)', 'id IN (%Ld)',
$object_ids); $object_ids);
break; break;
case PhabricatorPHIDConstants::PHID_TYPE_MOCK: case PholioPHIDTypeMock::TYPECONST:
$objects = id(new PholioMock())->loadAllWhere( $objects = id(new PholioMock())->loadAllWhere(
'id IN (%Ld)', 'id IN (%Ld)',
$object_ids); $object_ids);

View file

@ -162,7 +162,6 @@ final class PhabricatorEdgeConfig extends PhabricatorEdgeConstants {
PhabricatorPHIDConstants::PHID_TYPE_POST => 'PhamePost', PhabricatorPHIDConstants::PHID_TYPE_POST => 'PhamePost',
PhabricatorPHIDConstants::PHID_TYPE_QUES => 'PonderQuestion', PhabricatorPHIDConstants::PHID_TYPE_QUES => 'PonderQuestion',
PhabricatorPHIDConstants::PHID_TYPE_ANSW => 'PonderAnswer', PhabricatorPHIDConstants::PHID_TYPE_ANSW => 'PonderAnswer',
PhabricatorPHIDConstants::PHID_TYPE_MOCK => 'PholioMock',
PhabricatorPHIDConstants::PHID_TYPE_MCRO => 'PhabricatorFileImageMacro', PhabricatorPHIDConstants::PHID_TYPE_MCRO => 'PhabricatorFileImageMacro',
PhabricatorPHIDConstants::PHID_TYPE_CONP => 'ConpherenceThread', PhabricatorPHIDConstants::PHID_TYPE_CONP => 'ConpherenceThread',
PhabricatorPHIDConstants::PHID_TYPE_WIKI => 'PhrictionDocument', PhabricatorPHIDConstants::PHID_TYPE_WIKI => 'PhrictionDocument',

View file

@ -234,7 +234,7 @@ final class PHUIFeedStoryView extends AphrontView {
public function setAppIconFromPHID($phid) { public function setAppIconFromPHID($phid) {
switch (phid_get_type($phid)) { switch (phid_get_type($phid)) {
case PhabricatorPHIDConstants::PHID_TYPE_MOCK: case PholioPHIDTypeMock::TYPECONST:
$this->setAppIcon("pholio-dark"); $this->setAppIcon("pholio-dark");
break; break;
case PhabricatorPHIDConstants::PHID_TYPE_MCRO: case PhabricatorPHIDConstants::PHID_TYPE_MCRO: