mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-20 03:31:10 +01:00
Add additional protections against local repository misconfigurations
Summary: We've hit a couple of these in the wild, raise better error messages when the local repo is toast / broken / nonsense. Test Plan: Broke my local repo in all of the different ways we test for, verified I got an error message in each case. Reviewers: btrahan, abirchall Reviewed By: btrahan CC: aran, epriestley Maniphest Tasks: T964, T924 Differential Revision: https://secure.phabricator.com/D1855
This commit is contained in:
parent
ef74b9b88b
commit
def19bb8de
2 changed files with 53 additions and 0 deletions
|
@ -37,6 +37,57 @@ final class PhabricatorRepositoryGitFetchDaemon
|
||||||
PhabricatorRepository $repository,
|
PhabricatorRepository $repository,
|
||||||
$local_path) {
|
$local_path) {
|
||||||
|
|
||||||
|
// Run a bunch of sanity checks to detect people checking out repositories
|
||||||
|
// inside other repositories, making empty directories, pointing the local
|
||||||
|
// path at some random file or path, etc.
|
||||||
|
|
||||||
|
list($err, $stdout) = $repository->execLocalCommand(
|
||||||
|
'rev-parse --show-toplevel');
|
||||||
|
|
||||||
|
if ($err) {
|
||||||
|
|
||||||
|
// Try to raise a more tailored error message in the more common case
|
||||||
|
// of the user creating an empty directory. (We could try to remove it,
|
||||||
|
// but might not be able to, and it's much simpler to raise a good
|
||||||
|
// message than try to navigate those waters.)
|
||||||
|
if (is_dir($local_path)) {
|
||||||
|
$files = Filesystem::listDirectory($local_path, $include_hidden = true);
|
||||||
|
if (!$files) {
|
||||||
|
throw new Exception(
|
||||||
|
"Expected to find a git repository at '{$local_path}', but there ".
|
||||||
|
"is an empty directory there. Remove the directory: the daemon ".
|
||||||
|
"will run 'git clone' for you.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new Exception(
|
||||||
|
"Expected to find a git repository at '{$local_path}', but there is ".
|
||||||
|
"a non-repository directory (with other stuff in it) there. Move or ".
|
||||||
|
"remove this directory (or reconfigure the repository to use a ".
|
||||||
|
"different directory), and then either clone a repository yourself ".
|
||||||
|
"or let the daemon do it.");
|
||||||
|
} else {
|
||||||
|
$repo_path = rtrim($stdout, "\n");
|
||||||
|
|
||||||
|
if (empty($repo_path)) {
|
||||||
|
throw new Exception(
|
||||||
|
"Expected to find a git repository at '{$local_path}', but ".
|
||||||
|
"there was no result from `git rev-parse --show-toplevel`. ".
|
||||||
|
"Something is misconfigured or broken. The git repository ".
|
||||||
|
"may be inside a '.git/' directory.");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!Filesystem::pathsAreEquivalent($repo_path, $local_path)) {
|
||||||
|
throw new Exception(
|
||||||
|
"Expected to find repo at '{$local_path}', but the actual ".
|
||||||
|
"git repository root for this directory is '{$repo_path}'. ".
|
||||||
|
"Something is misconfigured. The repository's 'Local Path' should ".
|
||||||
|
"be set to some place where the daemon can check out a working ".
|
||||||
|
"copy, and should not be inside another git repository.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// This is a local command, but needs credentials.
|
// This is a local command, but needs credentials.
|
||||||
$future = $repository->getRemoteCommandFuture('fetch --all --prune');
|
$future = $repository->getRemoteCommandFuture('fetch --all --prune');
|
||||||
$future->setCWD($local_path);
|
$future->setCWD($local_path);
|
||||||
|
|
|
@ -9,5 +9,7 @@
|
||||||
phutil_require_module('phabricator', 'applications/repository/constants/repositorytype');
|
phutil_require_module('phabricator', 'applications/repository/constants/repositorytype');
|
||||||
phutil_require_module('phabricator', 'applications/repository/daemon/pulllocal');
|
phutil_require_module('phabricator', 'applications/repository/daemon/pulllocal');
|
||||||
|
|
||||||
|
phutil_require_module('phutil', 'filesystem');
|
||||||
|
|
||||||
|
|
||||||
phutil_require_source('PhabricatorRepositoryGitFetchDaemon.php');
|
phutil_require_source('PhabricatorRepositoryGitFetchDaemon.php');
|
||||||
|
|
Loading…
Reference in a new issue