aboutsummaryrefslogtreecommitdiff
path: root/www/fork-remote.php
diff options
context:
space:
mode:
authorChristian Weiske <cweiske@cweiske.de>2012-09-19 23:55:07 +0200
committerChristian Weiske <cweiske@cweiske.de>2012-09-19 23:55:07 +0200
commitc85fb1700ce938f28da420af9636e246912a996b (patch)
tree4d95a1e62726e3d218335e63c983406e0da1e3cf /www/fork-remote.php
parent8701af280fa5a9c83827cdd0e2ae335d2512a3a7 (diff)
downloadphorkie-c85fb1700ce938f28da420af9636e246912a996b.tar.gz
phorkie-c85fb1700ce938f28da420af9636e246912a996b.zip
implement request #13: simple remote forking works now
Diffstat (limited to 'www/fork-remote.php')
-rw-r--r--www/fork-remote.php31
1 files changed, 26 insertions, 5 deletions
diff --git a/www/fork-remote.php b/www/fork-remote.php
index dd58165..374c8b8 100644
--- a/www/fork-remote.php
+++ b/www/fork-remote.php
@@ -6,19 +6,40 @@ namespace phorkie;
*/
require_once 'www-header.php';
+$error = null;
+$urls = null;
if (isset($_POST['remote_url'])) {
$fr = new ForkRemote($_POST['remote_url']);
- $fr->parse();
- if ($fr->hasUniqueGitUrl()) {
- //FIXME: fork
+ if (false === $fr->parse()) {
+ //no url found
+ $error = 'No git:// clone URL found';
+ } else if (false !== ($gitUrl = $fr->getUniqueGitUrl())) {
+ $forker = new Forker();
+ $new = $forker->forkRemote($gitUrl);
+ redirect($new->getLink('display'));
+ } else {
+ //multiple urls found
+ $urls = $fr->getGitUrls();
+ }
+}
+
+$selsize = 0;
+if (is_array($urls)) {
+ foreach ($urls as $group) {
+ ++$selsize;
+ if (count($group) > 1) {
+ $selsize += count($group);
+ }
}
- //FIXME: display error or selection list
}
render(
'fork-remote',
array(
- 'remote_url' => isset($_POST['remote_url']) ? $_POST['remote_url'] : ''
+ 'remote_url' => isset($_POST['remote_url']) ? $_POST['remote_url'] : '',
+ 'error' => $error,
+ 'urls' => $urls,
+ 'urlselsize' => $selsize,
)
);
?>