mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-02 19:01:03 +01:00
Improve passphrase.query
Summary: Fixes T8070. Fixes T8071. Modernizes passphrase.query to support "order". Test Plan: - Saw description in results. - Queried for destroyed credentials with "needSecrets=true". - Used "order". Reviewers: btrahan Reviewed By: btrahan Subscribers: mikn, epriestley Maniphest Tasks: T8070, T8071 Differential Revision: https://secure.phabricator.com/D12715
This commit is contained in:
parent
84d0f1c41f
commit
a5402c46b2
1 changed files with 23 additions and 11 deletions
|
@ -11,13 +11,17 @@ final class PassphraseQueryConduitAPIMethod
|
||||||
return pht('Query credentials.');
|
return pht('Query credentials.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function newQueryObject() {
|
||||||
|
return new PassphraseCredentialQuery();
|
||||||
|
}
|
||||||
|
|
||||||
protected function defineParamTypes() {
|
protected function defineParamTypes() {
|
||||||
return array(
|
return array(
|
||||||
'ids' => 'optional list<int>',
|
'ids' => 'optional list<int>',
|
||||||
'phids' => 'optional list<phid>',
|
'phids' => 'optional list<phid>',
|
||||||
'needSecrets' => 'optional bool',
|
'needSecrets' => 'optional bool',
|
||||||
'needPublicKeys' => 'optional bool',
|
'needPublicKeys' => 'optional bool',
|
||||||
) + $this->getPagerParamTypes();
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function defineReturnType() {
|
protected function defineReturnType() {
|
||||||
|
@ -25,8 +29,7 @@ final class PassphraseQueryConduitAPIMethod
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function execute(ConduitAPIRequest $request) {
|
protected function execute(ConduitAPIRequest $request) {
|
||||||
$query = id(new PassphraseCredentialQuery())
|
$query = $this->newQueryForRequest($request);
|
||||||
->setViewer($request->getUser());
|
|
||||||
|
|
||||||
if ($request->getValue('ids')) {
|
if ($request->getValue('ids')) {
|
||||||
$query->withIDs($request->getValue('ids'));
|
$query->withIDs($request->getValue('ids'));
|
||||||
|
@ -58,14 +61,22 @@ final class PassphraseQueryConduitAPIMethod
|
||||||
$credential);
|
$credential);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$material = array();
|
||||||
|
|
||||||
$secret = null;
|
$secret = null;
|
||||||
if ($request->getValue('needSecrets')) {
|
if ($request->getValue('needSecrets')) {
|
||||||
if ($credential->getAllowConduit()) {
|
if ($credential->getAllowConduit()) {
|
||||||
$secret = $credential->getSecret()->openEnvelope();
|
$secret = $credential->getSecret();
|
||||||
|
if ($secret) {
|
||||||
|
$secret = $secret->openEnvelope();
|
||||||
|
} else {
|
||||||
|
$material['destroyed'] = pht(
|
||||||
|
'The private material for this credential has been '.
|
||||||
|
'destroyed.');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$material = array();
|
|
||||||
switch ($credential->getCredentialType()) {
|
switch ($credential->getCredentialType()) {
|
||||||
case PassphraseCredentialTypeSSHPrivateKeyFile::CREDENTIAL_TYPE:
|
case PassphraseCredentialTypeSSHPrivateKeyFile::CREDENTIAL_TYPE:
|
||||||
if ($secret) {
|
if ($secret) {
|
||||||
|
@ -93,8 +104,8 @@ final class PassphraseQueryConduitAPIMethod
|
||||||
|
|
||||||
if (!$credential->getAllowConduit()) {
|
if (!$credential->getAllowConduit()) {
|
||||||
$material['noAPIAccess'] = pht(
|
$material['noAPIAccess'] = pht(
|
||||||
'This credential\'s private material '.
|
'This private material for this credential is not accessible via '.
|
||||||
'is not accessible via API calls.');
|
'API calls.');
|
||||||
}
|
}
|
||||||
|
|
||||||
$results[$credential->getPHID()] = array(
|
$results[$credential->getPHID()] = array(
|
||||||
|
@ -102,6 +113,7 @@ final class PassphraseQueryConduitAPIMethod
|
||||||
'phid' => $credential->getPHID(),
|
'phid' => $credential->getPHID(),
|
||||||
'type' => $credential->getCredentialType(),
|
'type' => $credential->getCredentialType(),
|
||||||
'name' => $credential->getName(),
|
'name' => $credential->getName(),
|
||||||
|
'description' => $credential->getDescription(),
|
||||||
'uri' =>
|
'uri' =>
|
||||||
PhabricatorEnv::getProductionURI('/'.$credential->getMonogram()),
|
PhabricatorEnv::getProductionURI('/'.$credential->getMonogram()),
|
||||||
'monogram' => $credential->getMonogram(),
|
'monogram' => $credential->getMonogram(),
|
||||||
|
|
Loading…
Reference in a new issue