X-Git-Url: https://git.cweiske.de/phorkie.git/blobdiff_plain/f7101de3d20753dafe8e02f4e43112e2e208b8d7..92d6cf1f537c2126baf324cbdadbef1067e156b6:/www/fork.php diff --git a/www/fork.php b/www/fork.php index 5004945..10bd1e2 100644 --- a/www/fork.php +++ b/www/fork.php @@ -2,18 +2,33 @@ /** * Fork a repository */ -namespace Phorkie; +namespace phorkie; +$secureAtLevel = '1'; require_once 'www-header.php'; + +if ($_SERVER['REQUEST_METHOD'] !== 'POST') { + throw new Exception_Input('Forking only possible via POST'); +} + $repo = new Repository(); $repo->loadFromRequest(); $rs = new Repositories(); $new = $rs->createNew(); -$new->getVc()->getCommand('clone') - ->addArgument($repo->repoDir) - ->addArgument($new->repoDir) +$vc = $new->getVc(); +\rmdir($new->gitDir);//VersionControl_Git wants an existing dir, git clone not +$vc->getCommand('clone') + //this should be setOption, but it fails with a = between name and value + ->addArgument('--separate-git-dir') + ->addArgument($GLOBALS['phorkie']['cfg']['gitdir'] . '/' . $new->id . '.git') + ->addArgument($repo->gitDir) + ->addArgument($new->workDir) ->execute(); -\copy($repo->repoDir . '/.git/description', $new->repoDir . '/.git/description'); +\copy($repo->gitDir . '/description', $new->gitDir . '/description'); +foreach (\glob($new->gitDir . '/hooks/*') as $hookfile) { + \unlink($hookfile); +} + //FIXME: where to put fork source link? redirect($new->getLink('display')); -?> \ No newline at end of file +?>