Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F14730288
D15821.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
13 KB
Referenced Files
None
Subscribers
None
D15821.diff
View Options
diff --git a/src/__phutil_library_map__.php b/src/__phutil_library_map__.php
--- a/src/__phutil_library_map__.php
+++ b/src/__phutil_library_map__.php
@@ -816,6 +816,7 @@
'DiffusionTagListController' => 'applications/diffusion/controller/DiffusionTagListController.php',
'DiffusionTagListView' => 'applications/diffusion/view/DiffusionTagListView.php',
'DiffusionTagsQueryConduitAPIMethod' => 'applications/diffusion/conduit/DiffusionTagsQueryConduitAPIMethod.php',
+ 'DiffusionURIEditConduitAPIMethod' => 'applications/diffusion/conduit/DiffusionURIEditConduitAPIMethod.php',
'DiffusionURIEditEngine' => 'applications/diffusion/editor/DiffusionURIEditEngine.php',
'DiffusionURIEditor' => 'applications/diffusion/editor/DiffusionURIEditor.php',
'DiffusionURITestCase' => 'applications/diffusion/request/__tests__/DiffusionURITestCase.php',
@@ -5044,6 +5045,7 @@
'DiffusionTagListController' => 'DiffusionController',
'DiffusionTagListView' => 'DiffusionView',
'DiffusionTagsQueryConduitAPIMethod' => 'DiffusionQueryConduitAPIMethod',
+ 'DiffusionURIEditConduitAPIMethod' => 'PhabricatorEditEngineAPIMethod',
'DiffusionURIEditEngine' => 'PhabricatorEditEngine',
'DiffusionURIEditor' => 'PhabricatorApplicationTransactionEditor',
'DiffusionURITestCase' => 'PhutilTestCase',
diff --git a/src/applications/diffusion/conduit/DiffusionURIEditConduitAPIMethod.php b/src/applications/diffusion/conduit/DiffusionURIEditConduitAPIMethod.php
new file mode 100644
--- /dev/null
+++ b/src/applications/diffusion/conduit/DiffusionURIEditConduitAPIMethod.php
@@ -0,0 +1,20 @@
+<?php
+
+final class DiffusionURIEditConduitAPIMethod
+ extends PhabricatorEditEngineAPIMethod {
+
+ public function getAPIMethodName() {
+ return 'diffusion.uri.edit';
+ }
+
+ public function newEditEngine() {
+ return new DiffusionURIEditEngine();
+ }
+
+ public function getMethodSummary() {
+ return pht(
+ 'Apply transactions to create a new repository URI or edit an existing '.
+ 'one.');
+ }
+
+}
diff --git a/src/applications/diffusion/editor/DiffusionURIEditEngine.php b/src/applications/diffusion/editor/DiffusionURIEditEngine.php
--- a/src/applications/diffusion/editor/DiffusionURIEditEngine.php
+++ b/src/applications/diffusion/editor/DiffusionURIEditEngine.php
@@ -37,8 +37,15 @@
}
protected function newEditableObject() {
+ $uri = PhabricatorRepositoryURI::initializeNewURI();
+
$repository = $this->getRepository();
- return PhabricatorRepositoryURI::initializeNewURI($repository);
+ if ($repository) {
+ $uri->setRepositoryPHID($repository->getPHID());
+ $uri->attachRepository($repository);
+ }
+
+ return $uri;
}
protected function newObjectQuery() {
@@ -77,6 +84,23 @@
$viewer = $this->getViewer();
return array(
+ id(new PhabricatorHandlesEditField())
+ ->setKey('repository')
+ ->setAliases(array('repositoryPHID'))
+ ->setLabel(pht('Repository'))
+ ->setIsRequired(true)
+ ->setIsConduitOnly(true)
+ ->setTransactionType(
+ PhabricatorRepositoryURITransaction::TYPE_REPOSITORY)
+ ->setDescription(pht('The repository this URI is associated with.'))
+ ->setConduitDescription(
+ pht(
+ 'Create a URI in a given repository. This transaction type '.
+ 'must be present when creating a new URI and must not be '.
+ 'present when editing an existing URI.'))
+ ->setConduitTypeDescription(
+ pht('Repository PHID to create a new URI for.'))
+ ->setSingleValue($object->getRepositoryPHID()),
id(new PhabricatorTextEditField())
->setKey('uri')
->setLabel(pht('URI'))
@@ -104,6 +128,28 @@
->setConduitTypeDescription(pht('New display behavior.'))
->setValue($object->getDisplayType())
->setOptions($object->getAvailableDisplayTypeOptions()),
+ id(new PhabricatorHandlesEditField())
+ ->setKey('credential')
+ ->setAliases(array('credentialPHID'))
+ ->setLabel(pht('Credential'))
+ ->setIsConduitOnly(true)
+ ->setTransactionType(
+ PhabricatorRepositoryURITransaction::TYPE_CREDENTIAL)
+ ->setDescription(
+ pht('The credential to use when interacting with this URI.'))
+ ->setConduitDescription(pht('Change the credential for this URI.'))
+ ->setConduitTypeDescription(pht('New credential PHID, or null.'))
+ ->setSingleValue($object->getCredentialPHID()),
+ id(new PhabricatorBoolEditField())
+ ->setKey('disable')
+ ->setLabel(pht('Disabled'))
+ ->setIsConduitOnly(true)
+ ->setTransactionType(PhabricatorRepositoryURITransaction::TYPE_DISABLE)
+ ->setDescription(pht('Active status of the URI.'))
+ ->setConduitDescription(pht('Disable or activate the URI.'))
+ ->setConduitTypeDescription(pht('True to disable the URI.'))
+ ->setOptions(pht('Enable'), pht('Disable'))
+ ->setValue($object->getIsDisabled()),
);
}
diff --git a/src/applications/diffusion/editor/DiffusionURIEditor.php b/src/applications/diffusion/editor/DiffusionURIEditor.php
--- a/src/applications/diffusion/editor/DiffusionURIEditor.php
+++ b/src/applications/diffusion/editor/DiffusionURIEditor.php
@@ -14,9 +14,12 @@
public function getTransactionTypes() {
$types = parent::getTransactionTypes();
+ $types[] = PhabricatorRepositoryURITransaction::TYPE_REPOSITORY;
$types[] = PhabricatorRepositoryURITransaction::TYPE_URI;
$types[] = PhabricatorRepositoryURITransaction::TYPE_IO;
$types[] = PhabricatorRepositoryURITransaction::TYPE_DISPLAY;
+ $types[] = PhabricatorRepositoryURITransaction::TYPE_CREDENTIAL;
+ $types[] = PhabricatorRepositoryURITransaction::TYPE_DISABLE;
return $types;
}
@@ -32,6 +35,12 @@
return $object->getIOType();
case PhabricatorRepositoryURITransaction::TYPE_DISPLAY:
return $object->getDisplayType();
+ case PhabricatorRepositoryURITransaction::TYPE_REPOSITORY:
+ return $object->getRepositoryPHID();
+ case PhabricatorRepositoryURITransaction::TYPE_CREDENTIAL:
+ return $object->getCredentialPHID();
+ case PhabricatorRepositoryURITransaction::TYPE_DISABLE:
+ return (int)$object->getIsDisabled();
}
return parent::getCustomTransactionOldValue($object, $xaction);
@@ -45,7 +54,11 @@
case PhabricatorRepositoryURITransaction::TYPE_URI:
case PhabricatorRepositoryURITransaction::TYPE_IO:
case PhabricatorRepositoryURITransaction::TYPE_DISPLAY:
+ case PhabricatorRepositoryURITransaction::TYPE_REPOSITORY:
+ case PhabricatorRepositoryURITransaction::TYPE_CREDENTIAL:
return $xaction->getNewValue();
+ case PhabricatorRepositoryURITransaction::TYPE_DISABLE:
+ return (int)$xaction->getNewValue();
}
return parent::getCustomTransactionNewValue($object, $xaction);
@@ -65,6 +78,15 @@
case PhabricatorRepositoryURITransaction::TYPE_DISPLAY:
$object->setDisplayType($xaction->getNewValue());
break;
+ case PhabricatorRepositoryURITransaction::TYPE_REPOSITORY:
+ $object->setRepositoryPHID($xaction->getNewValue());
+ break;
+ case PhabricatorRepositoryURITransaction::TYPE_CREDENTIAL:
+ $object->setCredentialPHID($xaction->getNewValue());
+ break;
+ case PhabricatorRepositoryURITransaction::TYPE_DISABLE:
+ $object->setIsDisabled($xaction->getNewValue());
+ break;
}
}
@@ -76,6 +98,9 @@
case PhabricatorRepositoryURITransaction::TYPE_URI:
case PhabricatorRepositoryURITransaction::TYPE_IO:
case PhabricatorRepositoryURITransaction::TYPE_DISPLAY:
+ case PhabricatorRepositoryURITransaction::TYPE_REPOSITORY:
+ case PhabricatorRepositoryURITransaction::TYPE_CREDENTIAL:
+ case PhabricatorRepositoryURITransaction::TYPE_DISABLE:
return;
}
@@ -90,6 +115,92 @@
$errors = parent::validateTransaction($object, $type, $xactions);
switch ($type) {
+ case PhabricatorRepositoryURITransaction::TYPE_REPOSITORY:
+ $missing = $this->validateIsEmptyTextField(
+ $object->getRepositoryPHID(),
+ $xactions);
+ if ($missing) {
+ // NOTE: This isn't being marked as a missing field error because
+ // it's a fundamental, required property of the URI.
+ $errors[] = new PhabricatorApplicationTransactionValidationError(
+ $type,
+ pht('Required'),
+ pht(
+ 'When creating a repository URI, you must specify which '.
+ 'repository the URI will belong to.'),
+ nonempty(last($xactions), null));
+ break;
+ }
+
+ $viewer = $this->getActor();
+
+ foreach ($xactions as $xaction) {
+ $repository_phid = $xaction->getNewValue();
+
+ // If this isn't changing anything, let it through as-is.
+ if ($repository_phid == $object->getRepositoryPHID()) {
+ continue;
+ }
+
+ if (!$this->getIsNewObject()) {
+ $errors[] = new PhabricatorApplicationTransactionValidationError(
+ $type,
+ pht('Invalid'),
+ pht(
+ 'The repository a URI is associated with is immutable, and '.
+ 'can not be changed after the URI is created.'),
+ $xaction);
+ continue;
+ }
+
+ $repository = id(new PhabricatorRepositoryQuery())
+ ->setViewer($viewer)
+ ->withPHIDs(array($repository_phid))
+ ->requireCapabilities(
+ array(
+ PhabricatorPolicyCapability::CAN_VIEW,
+ PhabricatorPolicyCapability::CAN_EDIT,
+ ))
+ ->executeOne();
+ if (!$repository) {
+ $errors[] = new PhabricatorApplicationTransactionValidationError(
+ $type,
+ pht('Invalid'),
+ pht(
+ 'To create a URI for a repository ("%s"), it must exist and '.
+ 'you must have permission to edit it.',
+ $repository_phid),
+ $xaction);
+ continue;
+ }
+ }
+ break;
+ case PhabricatorRepositoryURITransaction::TYPE_CREDENTIAL:
+ $viewer = $this->getActor();
+ foreach ($xactions as $xaction) {
+ $credential_phid = $xaction->getNewValue();
+
+ if ($credential_phid == $object->getCredentialPHID()) {
+ continue;
+ }
+
+ $credential = id(new PassphraseCredentialQuery())
+ ->setViewer($viewer)
+ ->withPHIDs(array($credential_phid))
+ ->executeOne();
+ if (!$credential) {
+ $errors[] = new PhabricatorApplicationTransactionValidationError(
+ $type,
+ pht('Invalid'),
+ pht(
+ 'You can only associate a credential ("%s") with a repository '.
+ 'URI if it exists and you have permission to see it.',
+ $credential_phid),
+ $xaction);
+ continue;
+ }
+ }
+ break;
case PhabricatorRepositoryURITransaction::TYPE_URI:
$missing = $this->validateIsEmptyTextField(
$object->getURI(),
@@ -99,7 +210,7 @@
$error = new PhabricatorApplicationTransactionValidationError(
$type,
pht('Required'),
- pht('Repository URI is required.'),
+ pht('A repository URI must have a nonempty URI.'),
nonempty(last($xactions), null));
$error->setIsMissingFieldError(true);
diff --git a/src/applications/repository/storage/PhabricatorRepository.php b/src/applications/repository/storage/PhabricatorRepository.php
--- a/src/applications/repository/storage/PhabricatorRepository.php
+++ b/src/applications/repository/storage/PhabricatorRepository.php
@@ -2179,7 +2179,9 @@
$uris = array();
foreach ($protocol_map as $protocol => $proto_supported) {
foreach ($identifier_map as $identifier => $id_supported) {
- $uris[] = PhabricatorRepositoryURI::initializeNewURI($this)
+ $uris[] = PhabricatorRepositoryURI::initializeNewURI()
+ ->setRepositoryPHID($this->getPHID())
+ ->attachRepository($this)
->setBuiltinProtocol($protocol)
->setBuiltinIdentifier($identifier)
->setIsDisabled(!$proto_supported || !$id_supported);
diff --git a/src/applications/repository/storage/PhabricatorRepositoryURI.php b/src/applications/repository/storage/PhabricatorRepositoryURI.php
--- a/src/applications/repository/storage/PhabricatorRepositoryURI.php
+++ b/src/applications/repository/storage/PhabricatorRepositoryURI.php
@@ -62,10 +62,8 @@
) + parent::getConfiguration();
}
- public static function initializeNewURI(PhabricatorRepository $repository) {
+ public static function initializeNewURI() {
return id(new self())
- ->attachRepository($repository)
- ->setRepositoryPHID($repository->getPHID())
->setIoType(self::IO_DEFAULT)
->setDisplayType(self::DISPLAY_DEFAULT)
->setIsDisabled(0);
diff --git a/src/applications/repository/storage/PhabricatorRepositoryURITransaction.php b/src/applications/repository/storage/PhabricatorRepositoryURITransaction.php
--- a/src/applications/repository/storage/PhabricatorRepositoryURITransaction.php
+++ b/src/applications/repository/storage/PhabricatorRepositoryURITransaction.php
@@ -3,9 +3,12 @@
final class PhabricatorRepositoryURITransaction
extends PhabricatorApplicationTransaction {
+ const TYPE_REPOSITORY = 'diffusion.uri.repository';
const TYPE_URI = 'diffusion.uri.uri';
const TYPE_IO = 'diffusion.uri.io';
const TYPE_DISPLAY = 'diffusion.uri.display';
+ const TYPE_CREDENTIAL = 'diffusion.uri.credential';
+ const TYPE_DISABLE = 'diffusion.uri.disable';
public function getApplicationName() {
return 'repository';
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Sun, Jan 19, 7:25 AM (1 h, 1 m)
Storage Engine
blob
Storage Format
Encrypted (AES-256-CBC)
Storage Handle
7001739
Default Alt Text
D15821.diff (13 KB)
Attached To
Mode
D15821: Add `diffusion.uri.edit` for creating and editing repository URIs
Attached
Detach File
Event Timeline
Log In to Comment