mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-18 10:41:08 +01:00
Distinguish between "Remote URI" and "Clone URI" in Repositories
Summary: Hosted repositories have muddied this distinction somewhat. In some cases, we only want to use the real remote URI, and the call is only relevant for imported repositories. In other cases, we want the URI we'd plug into `git clone`. Move this logic into `PhabricatorRepository` and make the distinction more clear. Test Plan: Viewed SVN, Git, and Mercurial hosted and remote repositories, all the URIs looked reasonable. Reviewers: btrahan Reviewed By: btrahan CC: aran, dctrwatson Differential Revision: https://secure.phabricator.com/D8096
This commit is contained in:
parent
f585f6fddd
commit
96dd530c44
5 changed files with 120 additions and 53 deletions
|
@ -33,7 +33,7 @@ final class DiffusionExternalController extends DiffusionController {
|
|||
if ($remote_uri->getPath() == $uri_path) {
|
||||
$matches[$key] = 1;
|
||||
}
|
||||
if ($repository->getPublicRemoteURI() == $uri) {
|
||||
if ($repository->getPublicCloneURI() == $uri) {
|
||||
$matches[$key] = 2;
|
||||
}
|
||||
if ($repository->getRemoteURI() == $uri) {
|
||||
|
|
|
@ -174,42 +174,21 @@ final class DiffusionRepositoryController extends DiffusionController {
|
|||
}
|
||||
|
||||
if ($repository->isHosted()) {
|
||||
$serve_off = PhabricatorRepository::SERVE_OFF;
|
||||
$callsign = $repository->getCallsign();
|
||||
$repo_path = '/diffusion/'.$callsign.'/';
|
||||
|
||||
$serve_ssh = $repository->getServeOverSSH();
|
||||
if ($serve_ssh !== $serve_off) {
|
||||
$uri = new PhutilURI(PhabricatorEnv::getProductionURI($repo_path));
|
||||
|
||||
if ($repository->isSVN()) {
|
||||
$uri->setProtocol('svn+ssh');
|
||||
} else {
|
||||
$uri->setProtocol('ssh');
|
||||
}
|
||||
|
||||
$ssh_user = PhabricatorEnv::getEnvConfig('diffusion.ssh-user');
|
||||
if ($ssh_user) {
|
||||
$uri->setUser($ssh_user);
|
||||
}
|
||||
|
||||
$uri->setPort(PhabricatorEnv::getEnvConfig('diffusion.ssh-port'));
|
||||
|
||||
$ssh_uri = $repository->getSSHCloneURIObject();
|
||||
if ($ssh_uri) {
|
||||
$clone_uri = $this->renderCloneURI(
|
||||
$uri,
|
||||
$serve_ssh,
|
||||
$ssh_uri,
|
||||
$repository->getServeOverSSH(),
|
||||
'/settings/panel/ssh/');
|
||||
|
||||
$view->addProperty(pht('Clone URI (SSH)'), $clone_uri);
|
||||
}
|
||||
|
||||
$serve_http = $repository->getServeOverHTTP();
|
||||
if ($serve_http !== $serve_off) {
|
||||
$http_uri = PhabricatorEnv::getProductionURI($repo_path);
|
||||
|
||||
$http_uri = $repository->getHTTPCloneURIObject();
|
||||
if ($http_uri) {
|
||||
$clone_uri = $this->renderCloneURI(
|
||||
$http_uri,
|
||||
$serve_http,
|
||||
$repository->getServeOverHTTP(),
|
||||
PhabricatorEnv::getEnvConfig('diffusion.allow-http-auth')
|
||||
? '/settings/panel/vcspassword/'
|
||||
: null);
|
||||
|
@ -223,13 +202,13 @@ final class DiffusionRepositoryController extends DiffusionController {
|
|||
$view->addProperty(
|
||||
pht('Clone URI'),
|
||||
$this->renderCloneURI(
|
||||
$repository->getPublicRemoteURI()));
|
||||
$repository->getPublicCloneURI()));
|
||||
break;
|
||||
case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
|
||||
$view->addProperty(
|
||||
pht('Repository Root'),
|
||||
$this->renderCloneURI(
|
||||
$repository->getPublicRemoteURI()));
|
||||
$repository->getPublicCloneURI()));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -175,7 +175,7 @@ final class HarbormasterBuild extends HarbormasterDAO
|
|||
if ($repo) {
|
||||
$results['repository.callsign'] = $repo->getCallsign();
|
||||
$results['repository.vcs'] = $repo->getVersionControlSystem();
|
||||
$results['repository.uri'] = $repo->getPublicRemoteURI();
|
||||
$results['repository.uri'] = $repo->getPublicCloneURI();
|
||||
}
|
||||
|
||||
$results['step.timestamp'] = time();
|
||||
|
|
|
@ -486,11 +486,7 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
|
|||
}
|
||||
|
||||
public function getNormalizedPath() {
|
||||
if ($this->isHosted()) {
|
||||
$uri = PhabricatorEnv::getProductionURI($this->getURI());
|
||||
} else {
|
||||
$uri = $this->getRemoteURI();
|
||||
}
|
||||
$uri = (string)$this->getCloneURIObject();
|
||||
|
||||
switch ($this->getVersionControlSystem()) {
|
||||
case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
|
||||
|
@ -629,6 +625,7 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
|
|||
return (bool)$this->getDetail('importing', false);
|
||||
}
|
||||
|
||||
|
||||
/* -( Repository URI Management )------------------------------------------ */
|
||||
|
||||
|
||||
|
@ -675,19 +672,21 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
|
|||
|
||||
|
||||
/**
|
||||
* Get the remote URI for this repository, without authentication information.
|
||||
* Get the clone (or checkout) URI for this repository, without authentication
|
||||
* information.
|
||||
*
|
||||
* @return string Repository URI.
|
||||
* @task uri
|
||||
*/
|
||||
public function getPublicRemoteURI() {
|
||||
$uri = $this->getRemoteURIObject();
|
||||
public function getPublicCloneURI() {
|
||||
$uri = $this->getCloneURIObject();
|
||||
|
||||
// Make sure we don't leak anything if this repo is using HTTP Basic Auth
|
||||
// with the credentials in the URI or something zany like that.
|
||||
|
||||
// If repository is not accessed over SSH we remove both username and
|
||||
// password.
|
||||
if (!$this->isHosted()) {
|
||||
if (!$this->shouldUseSSH()) {
|
||||
$uri->setUser(null);
|
||||
|
||||
|
@ -697,6 +696,7 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
|
|||
$uri->setPass(null);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return (string)$uri;
|
||||
}
|
||||
|
@ -752,6 +752,94 @@ final class PhabricatorRepository extends PhabricatorRepositoryDAO
|
|||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the "best" clone/checkout URI for this repository, on any protocol.
|
||||
*/
|
||||
public function getCloneURIObject() {
|
||||
if (!$this->isHosted()) {
|
||||
return $this->getRemoteURIObject();
|
||||
}
|
||||
|
||||
// Choose the best URI: pick a read/write URI over a URI which is not
|
||||
// read/write, and SSH over HTTP.
|
||||
|
||||
$serve_ssh = $this->getServeOverSSH();
|
||||
$serve_http = $this->getServeOverHTTP();
|
||||
|
||||
if ($serve_ssh === self::SERVE_READWRITE) {
|
||||
return $this->getSSHCloneURIObject();
|
||||
} else if ($serve_http === self::SERVE_READWRITE) {
|
||||
return $this->getHTTPCloneURIObject();
|
||||
} else if ($serve_ssh !== self::SERVE_OFF) {
|
||||
return $this->getSSHCloneURIObject();
|
||||
} else if ($serve_http !== self::SERVE_OFF) {
|
||||
return $this->getHTTPCloneURIObject();
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the repository's SSH clone/checkout URI, if one exists.
|
||||
*/
|
||||
public function getSSHCloneURIObject() {
|
||||
if (!$this->isHosted()) {
|
||||
if ($this->shouldUseSSH()) {
|
||||
return $this->getRemoteURIObject();
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
$serve_ssh = $this->getServeOverSSH();
|
||||
if ($serve_ssh === self::SERVE_OFF) {
|
||||
return null;
|
||||
}
|
||||
|
||||
$uri = new PhutilURI(PhabricatorEnv::getProductionURI($this->getURI()));
|
||||
|
||||
if ($this->isSVN()) {
|
||||
$uri->setProtocol('svn+ssh');
|
||||
} else {
|
||||
$uri->setProtocol('ssh');
|
||||
}
|
||||
|
||||
$ssh_user = PhabricatorEnv::getEnvConfig('diffusion.ssh-user');
|
||||
if ($ssh_user) {
|
||||
$uri->setUser($ssh_user);
|
||||
}
|
||||
|
||||
$uri->setPort(PhabricatorEnv::getEnvConfig('diffusion.ssh-port'));
|
||||
|
||||
return $uri;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Get the repository's HTTP clone/checkout URI, if one exists.
|
||||
*/
|
||||
public function getHTTPCloneURIObject() {
|
||||
if (!$this->isHosted()) {
|
||||
if ($this->shouldUseHTTP()) {
|
||||
return $this->getRemoteURIObject();
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
$serve_http = $this->getServeOverHTTP();
|
||||
if ($serve_http === self::SERVE_OFF) {
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
$uri = PhabricatorEnv::getProductionURI($this->getURI());
|
||||
|
||||
return $uri;
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Determine if we should connect to the remote using SSH flags and
|
||||
* credentials.
|
||||
|
|
|
@ -38,21 +38,21 @@ final class PhabricatorRepositoryURITestCase
|
|||
$repo->setVersionControlSystem($svn);
|
||||
|
||||
$this->assertEqual('http://example.com/', $repo->getRemoteURI());
|
||||
$this->assertEqual('http://example.com/', $repo->getPublicRemoteURI());
|
||||
$this->assertEqual('http://example.com/', $repo->getPublicCloneURI());
|
||||
$this->assertEqual('http://example.com/',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
$repo->setVersionControlSystem($git);
|
||||
|
||||
$this->assertEqual('http://example.com/', $repo->getRemoteURI());
|
||||
$this->assertEqual('http://example.com/', $repo->getPublicRemoteURI());
|
||||
$this->assertEqual('http://example.com/', $repo->getPublicCloneURI());
|
||||
$this->assertEqual('http://duck:quack@example.com/',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
$repo->setVersionControlSystem($hg);
|
||||
|
||||
$this->assertEqual('http://example.com/', $repo->getRemoteURI());
|
||||
$this->assertEqual('http://example.com/', $repo->getPublicRemoteURI());
|
||||
$this->assertEqual('http://example.com/', $repo->getPublicCloneURI());
|
||||
$this->assertEqual('http://duck:quack@example.com/',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
|
@ -62,21 +62,21 @@ final class PhabricatorRepositoryURITestCase
|
|||
$repo->setVersionControlSystem($svn);
|
||||
|
||||
$this->assertEqual('ssh://example.com/', $repo->getRemoteURI());
|
||||
$this->assertEqual('ssh://example.com/', $repo->getPublicRemoteURI());
|
||||
$this->assertEqual('ssh://example.com/', $repo->getPublicCloneURI());
|
||||
$this->assertEqual('ssh://example.com/',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
$repo->setVersionControlSystem($git);
|
||||
|
||||
$this->assertEqual('ssh://example.com/', $repo->getRemoteURI());
|
||||
$this->assertEqual('ssh://example.com/', $repo->getPublicRemoteURI());
|
||||
$this->assertEqual('ssh://example.com/', $repo->getPublicCloneURI());
|
||||
$this->assertEqual('ssh://example.com/',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
$repo->setVersionControlSystem($hg);
|
||||
|
||||
$this->assertEqual('ssh://example.com/', $repo->getRemoteURI());
|
||||
$this->assertEqual('ssh://example.com/', $repo->getPublicRemoteURI());
|
||||
$this->assertEqual('ssh://example.com/', $repo->getPublicCloneURI());
|
||||
$this->assertEqual('ssh://example.com/',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
|
@ -86,7 +86,7 @@ final class PhabricatorRepositoryURITestCase
|
|||
$repo->setVersionControlSystem($git);
|
||||
|
||||
$this->assertEqual('git@example.com:path.git', $repo->getRemoteURI());
|
||||
$this->assertEqual('git@example.com:path.git', $repo->getPublicRemoteURI());
|
||||
$this->assertEqual('git@example.com:path.git', $repo->getPublicCloneURI());
|
||||
$this->assertEqual('git@example.com:path.git',
|
||||
$repo->getRemoteURIEnvelope()->openEnvelope());
|
||||
|
||||
|
|
Loading…
Reference in a new issue