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

Add an edge between Passphrase credentials and objects which use them

Summary: Ref T4122. Add an edge to keep track of where a credential is used, and show it in the UI.

Test Plan:
See "Used By":

{F84099}

Reviewers: btrahan

Reviewed By: btrahan

CC: aran

Maniphest Tasks: T4122

Differential Revision: https://secure.phabricator.com/D7628
This commit is contained in:
epriestley 2013-11-22 15:23:23 -08:00
parent 61b26255bb
commit 819f899013
5 changed files with 39 additions and 1 deletions

View file

@ -0,0 +1,15 @@
CREATE TABLE {$NAMESPACE}_passphrase.edge (
src VARCHAR(64) NOT NULL COLLATE utf8_bin,
type VARCHAR(64) NOT NULL COLLATE utf8_bin,
dst VARCHAR(64) NOT NULL COLLATE utf8_bin,
dateCreated INT UNSIGNED NOT NULL,
seq INT UNSIGNED NOT NULL,
dataID INT UNSIGNED,
PRIMARY KEY (src, type, dst),
KEY (src, type, dateCreated, seq)
) ENGINE=InnoDB, COLLATE utf8_general_ci;
CREATE TABLE {$NAMESPACE}_passphrase.edgedata (
id INT UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT,
data LONGTEXT NOT NULL COLLATE utf8_bin
) ENGINE=InnoDB, COLLATE utf8_general_ci;

View file

@ -151,6 +151,17 @@ final class PassphraseCredentialViewController extends PassphraseController {
pht('Username'), pht('Username'),
$credential->getUsername()); $credential->getUsername());
$used_by_phids = PhabricatorEdgeQuery::loadDestinationPHIDs(
$credential->getPHID(),
PhabricatorEdgeConfig::TYPE_CREDENTIAL_USED_BY_OBJECT);
if ($used_by_phids) {
$this->loadHandles($used_by_phids);
$properties->addProperty(
pht('Used By'),
$this->renderHandlesForPHIDs($used_by_phids));
}
$description = $credential->getDescription(); $description = $credential->getDescription();
if (strlen($description)) { if (strlen($description)) {
$properties->addSectionHeader( $properties->addSectionHeader(

View file

@ -19,6 +19,7 @@ final class PassphraseCredential extends PassphraseDAO
return id(new PassphraseCredential()) return id(new PassphraseCredential())
->setName('') ->setName('')
->setUsername('') ->setUsername('')
->setDescription('')
->setIsDestroyed(0) ->setIsDestroyed(0)
->setViewPolicy($actor->getPHID()) ->setViewPolicy($actor->getPHID())
->setEditPolicy($actor->getPHID()); ->setEditPolicy($actor->getPHID());

View file

@ -60,6 +60,9 @@ final class PhabricatorEdgeConfig extends PhabricatorEdgeConstants {
const TYPE_MOCK_HAS_TASK = 37; const TYPE_MOCK_HAS_TASK = 37;
const TYPE_TASK_HAS_MOCK = 38; const TYPE_TASK_HAS_MOCK = 38;
const TYPE_OBJECT_USES_CREDENTIAL = 39;
const TYPE_CREDENTIAL_USED_BY_OBJECT = 40;
const TYPE_TEST_NO_CYCLE = 9000; const TYPE_TEST_NO_CYCLE = 9000;
const TYPE_PHOB_HAS_ASANATASK = 80001; const TYPE_PHOB_HAS_ASANATASK = 80001;
@ -71,6 +74,7 @@ final class PhabricatorEdgeConfig extends PhabricatorEdgeConstants {
const TYPE_PHOB_HAS_JIRAISSUE = 80004; const TYPE_PHOB_HAS_JIRAISSUE = 80004;
const TYPE_JIRAISSUE_HAS_PHOB = 80005; const TYPE_JIRAISSUE_HAS_PHOB = 80005;
public static function getInverse($edge_type) { public static function getInverse($edge_type) {
static $map = array( static $map = array(
self::TYPE_TASK_HAS_COMMIT => self::TYPE_COMMIT_HAS_TASK, self::TYPE_TASK_HAS_COMMIT => self::TYPE_COMMIT_HAS_TASK,
@ -134,7 +138,10 @@ final class PhabricatorEdgeConfig extends PhabricatorEdgeConstants {
self::TYPE_REVIEWER_FOR_DREV => self::TYPE_DREV_HAS_REVIEWER, self::TYPE_REVIEWER_FOR_DREV => self::TYPE_DREV_HAS_REVIEWER,
self::TYPE_PHOB_HAS_JIRAISSUE => self::TYPE_JIRAISSUE_HAS_PHOB, self::TYPE_PHOB_HAS_JIRAISSUE => self::TYPE_JIRAISSUE_HAS_PHOB,
self:: TYPE_JIRAISSUE_HAS_PHOB => self::TYPE_PHOB_HAS_JIRAISSUE self::TYPE_JIRAISSUE_HAS_PHOB => self::TYPE_PHOB_HAS_JIRAISSUE,
self::TYPE_OBJECT_USES_CREDENTIAL => self::TYPE_CREDENTIAL_USED_BY_OBJECT,
self::TYPE_CREDENTIAL_USED_BY_OBJECT => self::TYPE_OBJECT_USES_CREDENTIAL,
); );
return idx($map, $edge_type); return idx($map, $edge_type);

View file

@ -1772,6 +1772,10 @@ final class PhabricatorBuiltinPatchList extends PhabricatorSQLPatchList {
'type' => 'sql', 'type' => 'sql',
'name' => $this->getPatchPath('20131120.nuancesourcetype.sql'), 'name' => $this->getPatchPath('20131120.nuancesourcetype.sql'),
), ),
'20131121.passphraseedge.sql' => array(
'type' => 'sql',
'name' => $this->getPatchPath('20131121.passphraseedge.sql'),
),
); );
} }
} }