Allow Almanac Bindings to be enabled/disabled via API and support the "properties" attachment
Summary: Depends on D19340. Ref T12414. Ref T13120. See T12414 for some discussion about direction here. Since I think retaining "enabled/disabled" as a simple flag is reasonable, expose it via the API for readers and writers. Also expose binding properties. Test Plan: - Searched for bindings and properties with "alamanc.binding.search". - Enabled and disabled bindings with "almanac.binding.edit". Reviewers: amckinley Reviewed By: amckinley Maniphest Tasks: T13120, T12414 Differential Revision: https://secure.phabricator.com/D19341
This commit is contained in:
		| @@ -152,6 +152,19 @@ final class AlmanacBindingEditEngine | |||||||
|         ->setConduitDescription(pht('Set the interface to bind.')) |         ->setConduitDescription(pht('Set the interface to bind.')) | ||||||
|         ->setConduitTypeDescription(pht('Interface PHID.')) |         ->setConduitTypeDescription(pht('Interface PHID.')) | ||||||
|         ->setValue($object->getInterfacePHID()), |         ->setValue($object->getInterfacePHID()), | ||||||
|  |       id(new PhabricatorBoolEditField()) | ||||||
|  |         ->setKey('disabled') | ||||||
|  |         ->setLabel(pht('Disabled')) | ||||||
|  |         ->setIsConduitOnly(true) | ||||||
|  |         ->setTransactionType( | ||||||
|  |           AlmanacBindingDisableTransaction::TRANSACTIONTYPE) | ||||||
|  |         ->setDescription(pht('Disable or enable the binding.')) | ||||||
|  |         ->setConduitDescription(pht('Disable or enable the binding.')) | ||||||
|  |         ->setConduitTypeDescription(pht('True to disable the binding.')) | ||||||
|  |         ->setValue($object->getIsDisabled()) | ||||||
|  |         ->setOptions( | ||||||
|  |           pht('Enable Binding'), | ||||||
|  |           pht('Disable Binding')), | ||||||
|     ); |     ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -244,6 +244,10 @@ final class AlmanacBinding | |||||||
|         ->setKey('interfacePHID') |         ->setKey('interfacePHID') | ||||||
|         ->setType('phid') |         ->setType('phid') | ||||||
|         ->setDescription(pht('The interface the service is bound to.')), |         ->setDescription(pht('The interface the service is bound to.')), | ||||||
|  |       id(new PhabricatorConduitSearchFieldSpecification()) | ||||||
|  |         ->setKey('disabled') | ||||||
|  |         ->setType('bool') | ||||||
|  |         ->setDescription(pht('Interface status.')), | ||||||
|     ); |     ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -252,11 +256,15 @@ final class AlmanacBinding | |||||||
|       'servicePHID' => $this->getServicePHID(), |       'servicePHID' => $this->getServicePHID(), | ||||||
|       'devicePHID' => $this->getDevicePHID(), |       'devicePHID' => $this->getDevicePHID(), | ||||||
|       'interfacePHID' => $this->getInterfacePHID(), |       'interfacePHID' => $this->getInterfacePHID(), | ||||||
|  |       'disabled' => (bool)$this->getIsDisabled(), | ||||||
|     ); |     ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   public function getConduitSearchAttachments() { |   public function getConduitSearchAttachments() { | ||||||
|     return array(); |     return array( | ||||||
|  |       id(new AlmanacPropertiesSearchEngineAttachment()) | ||||||
|  |         ->setAttachmentKey('properties'), | ||||||
|  |     ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 epriestley
					epriestley