mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-23 21:18:19 +01:00
08bea1d363
Summary: Ref T10917. This primarily prepares these for transactions by giving us a place to: - review old deactivated keys; and - review changes to keys. Future changes will add transactions and a timeline so key changes are recorded exhaustively and can be more easily audited. Test Plan: {F1652089} {F1652090} {F1652091} {F1652092} Reviewers: chad Reviewed By: chad Maniphest Tasks: T10917 Differential Revision: https://secure.phabricator.com/D15946
78 lines
1.8 KiB
PHP
78 lines
1.8 KiB
PHP
<?php
|
|
|
|
abstract class PhabricatorAuthSSHKeyController
|
|
extends PhabricatorAuthController {
|
|
|
|
private $keyObject;
|
|
|
|
public function setSSHKeyObject(PhabricatorSSHPublicKeyInterface $object) {
|
|
$this->keyObject = $object;
|
|
return $this;
|
|
}
|
|
|
|
public function getSSHKeyObject() {
|
|
return $this->keyObject;
|
|
}
|
|
|
|
protected function loadSSHKeyObject($object_phid, $need_edit) {
|
|
$viewer = $this->getViewer();
|
|
|
|
$query = id(new PhabricatorObjectQuery())
|
|
->setViewer($viewer)
|
|
->withPHIDs(array($object_phid));
|
|
|
|
if ($need_edit) {
|
|
$query->requireCapabilities(
|
|
array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
));
|
|
}
|
|
|
|
$object = $query->executeOne();
|
|
|
|
if (!$object) {
|
|
return null;
|
|
}
|
|
|
|
// If this kind of object can't have SSH keys, don't let the viewer
|
|
// add them.
|
|
if (!($object instanceof PhabricatorSSHPublicKeyInterface)) {
|
|
return null;
|
|
}
|
|
|
|
$this->keyObject = $object;
|
|
|
|
return $object;
|
|
}
|
|
|
|
protected function newKeyForObjectPHID($object_phid) {
|
|
$viewer = $this->getViewer();
|
|
|
|
$object = $this->loadSSHKeyObject($object_phid, true);
|
|
if (!$object) {
|
|
return null;
|
|
}
|
|
|
|
return PhabricatorAuthSSHKey::initializeNewSSHKey($viewer, $object);
|
|
}
|
|
|
|
protected function buildApplicationCrumbs() {
|
|
$crumbs = parent::buildApplicationCrumbs();
|
|
$viewer = $this->getViewer();
|
|
|
|
$key_object = $this->getSSHKeyObject();
|
|
if ($key_object) {
|
|
$object_phid = $key_object->getPHID();
|
|
$handles = $viewer->loadHandles(array($object_phid));
|
|
$handle = $handles[$object_phid];
|
|
|
|
$uri = $key_object->getSSHPublicKeyManagementURI($viewer);
|
|
|
|
$crumbs->addTextCrumb($handle->getObjectName(), $uri);
|
|
}
|
|
|
|
return $crumbs;
|
|
}
|
|
|
|
}
|