mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-01 11:12:42 +01:00
4505724cc4
Summary: Ref T2783. This is primarily exploratory and just figuring out what we're blocked on: - Allow a Repository to be bound to a Service. The Service may eventually define multiple read/write nodes, etc. - There's no UI to do this binding yet, you have to touch the database manually. - If a repository is bound to a Service, effect Conduit calls via calls to the remote service instead of executing them in-process. - These don't actually work yet since there's no authentication (see T5955). Test Plan: - Made a nice Service with a nice Binding to a nice Interface on a nice Device. - Force-associated a repository with the service using a raw MySQL query. - Saw Phabricator try to make a remote call to the service (on localhost) and fail because of missing auth stuff. - Also ran `almanac.queryservices`. Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T2783 Differential Revision: https://secure.phabricator.com/D10982
181 lines
4.5 KiB
PHP
181 lines
4.5 KiB
PHP
<?php
|
|
|
|
final class AlmanacService
|
|
extends AlmanacDAO
|
|
implements
|
|
PhabricatorPolicyInterface,
|
|
PhabricatorCustomFieldInterface,
|
|
PhabricatorApplicationTransactionInterface,
|
|
PhabricatorProjectInterface,
|
|
AlmanacPropertyInterface {
|
|
|
|
protected $name;
|
|
protected $nameIndex;
|
|
protected $mailKey;
|
|
protected $viewPolicy;
|
|
protected $editPolicy;
|
|
|
|
private $customFields = self::ATTACHABLE;
|
|
private $almanacProperties = self::ATTACHABLE;
|
|
private $bindings = self::ATTACHABLE;
|
|
|
|
public static function initializeNewService() {
|
|
return id(new AlmanacService())
|
|
->setViewPolicy(PhabricatorPolicies::POLICY_USER)
|
|
->setEditPolicy(PhabricatorPolicies::POLICY_ADMIN)
|
|
->attachAlmanacProperties(array());
|
|
}
|
|
|
|
public function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_AUX_PHID => true,
|
|
self::CONFIG_COLUMN_SCHEMA => array(
|
|
'name' => 'text128',
|
|
'nameIndex' => 'bytes12',
|
|
'mailKey' => 'bytes20',
|
|
),
|
|
self::CONFIG_KEY_SCHEMA => array(
|
|
'key_name' => array(
|
|
'columns' => array('nameIndex'),
|
|
'unique' => true,
|
|
),
|
|
'key_nametext' => array(
|
|
'columns' => array('name'),
|
|
),
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public function generatePHID() {
|
|
return PhabricatorPHID::generateNewPHID(AlmanacServicePHIDType::TYPECONST);
|
|
}
|
|
|
|
public function save() {
|
|
AlmanacNames::validateServiceOrDeviceName($this->getName());
|
|
|
|
$this->nameIndex = PhabricatorHash::digestForIndex($this->getName());
|
|
|
|
if (!$this->mailKey) {
|
|
$this->mailKey = Filesystem::readRandomCharacters(20);
|
|
}
|
|
|
|
return parent::save();
|
|
}
|
|
|
|
public function getURI() {
|
|
return '/almanac/service/view/'.$this->getName().'/';
|
|
}
|
|
|
|
public function getBindings() {
|
|
return $this->assertAttached($this->bindings);
|
|
}
|
|
|
|
public function attachBindings(array $bindings) {
|
|
$this->bindings = $bindings;
|
|
return $this;
|
|
}
|
|
|
|
|
|
/* -( AlmanacPropertyInterface )------------------------------------------- */
|
|
|
|
|
|
public function attachAlmanacProperties(array $properties) {
|
|
assert_instances_of($properties, 'AlmanacProperty');
|
|
$this->almanacProperties = mpull($properties, null, 'getFieldName');
|
|
return $this;
|
|
}
|
|
|
|
public function getAlmanacProperties() {
|
|
return $this->assertAttached($this->almanacProperties);
|
|
}
|
|
|
|
public function hasAlmanacProperty($key) {
|
|
$this->assertAttached($this->almanacProperties);
|
|
return isset($this->almanacProperties[$key]);
|
|
}
|
|
|
|
public function getAlmanacProperty($key) {
|
|
return $this->assertAttachedKey($this->almanacProperties, $key);
|
|
}
|
|
|
|
public function getAlmanacPropertyValue($key, $default = null) {
|
|
if ($this->hasAlmanacProperty($key)) {
|
|
return $this->getAlmanacProperty($key)->getFieldValue();
|
|
} else {
|
|
return $default;
|
|
}
|
|
}
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
|
|
|
|
|
public function getCapabilities() {
|
|
return array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
);
|
|
}
|
|
|
|
public function getPolicy($capability) {
|
|
switch ($capability) {
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
return $this->getViewPolicy();
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
return $this->getEditPolicy();
|
|
}
|
|
}
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
return false;
|
|
}
|
|
|
|
public function describeAutomaticCapability($capability) {
|
|
return null;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorCustomFieldInterface )------------------------------------ */
|
|
|
|
|
|
public function getCustomFieldSpecificationForRole($role) {
|
|
return array();
|
|
}
|
|
|
|
public function getCustomFieldBaseClass() {
|
|
return 'AlmanacCustomField';
|
|
}
|
|
|
|
public function getCustomFields() {
|
|
return $this->assertAttached($this->customFields);
|
|
}
|
|
|
|
public function attachCustomFields(PhabricatorCustomFieldAttachment $fields) {
|
|
$this->customFields = $fields;
|
|
return $this;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorApplicationTransactionInterface )------------------------- */
|
|
|
|
|
|
public function getApplicationTransactionEditor() {
|
|
return new AlmanacServiceEditor();
|
|
}
|
|
|
|
public function getApplicationTransactionObject() {
|
|
return $this;
|
|
}
|
|
|
|
public function getApplicationTransactionTemplate() {
|
|
return new AlmanacServiceTransaction();
|
|
}
|
|
|
|
public function willRenderTimeline(
|
|
PhabricatorApplicationTransactionView $timeline,
|
|
AphrontRequest $request) {
|
|
|
|
return $timeline;
|
|
}
|
|
|
|
}
|