X-Git-Url: http://git.pjr.cc/?a=blobdiff_plain;f=gwvpmini%2Fgwvpmini_gitrepo.php;h=e20532eae9dbefa0e10607629d2bc8b61fbf9852;hb=39de15eac6b59d9c49634f63e6fcd3ca03082a12;hp=6f9264bd6ee7d0817ff358ac93ebb4d00584a331;hpb=42069486556c27a9ceff2108970c6fe1c5333bfd;p=gwvp-mini.git diff --git a/gwvpmini/gwvpmini_gitrepo.php b/gwvpmini/gwvpmini_gitrepo.php index 6f9264b..e20532e 100644 --- a/gwvpmini/gwvpmini_gitrepo.php +++ b/gwvpmini/gwvpmini_gitrepo.php @@ -3,7 +3,7 @@ global $HOME_PAGE_PROVIDERS; $CALL_ME_FUNCTIONS["repoadmin"] = "gwvpmini_RepoCallMe"; -$HOME_PAGE_PROVIDERS["gitlog"] = "gwvpmini_GitLogProvider"; +$HOME_PAGE_PROVIDERS["00gitlog"] = "gwvpmini_GitLogProvider"; // the home_page_provders bit is an array @@ -15,15 +15,15 @@ $MENU_ITEMS["10repos"]["link"] = "$BASE_URL/repos"; function gwvpmini_RepoCallMe() { - error_log("in repoadmin callme - err?"); - error_log(print_r($_REQUEST, true)); + // error_log("in repoadmin callme - err?"); + // error_log(print_r($_REQUEST, true)); if(isset($_REQUEST["q"])) { - error_log("in repoadmin callme, for Q"); + // error_log("in repoadmin callme, for Q"); $query = $_REQUEST["q"]; $qspl = explode("/", $query); if(isset($qspl[0])) { if($qspl[0] == "repos") { - error_log("in repos call"); + // error_log("in repos call"); if(isset($qspl[1])) { if($qspl[1] == "create") { return "gwvpmini_RepoCreate"; @@ -31,7 +31,7 @@ function gwvpmini_RepoCallMe() return "gwvpmini_RepoMainPage"; } } else { - error_log("i got here, where next?"); + // error_log("i got here, where next?"); return "gwvpmini_RepoMainPage"; } } else return false; @@ -51,9 +51,11 @@ function gwvpmini_RepoMainPage() function gwvpmini_RepoMainPageBody() { - gwvpmini_GitCreateRepoForm(); + global $BASE_URL; + if(gwvpmini_isLoggedIn()) { $repos = gwvpmini_GetOwnedRepos($_SESSION["username"]); + error_log("repos, ".print_r($repos, true)); if(!$repos) { echo "You currently own no repos
"; } else { @@ -62,14 +64,83 @@ function gwvpmini_RepoMainPageBody() foreach($repos as $repo) { $name = $repo["name"]; $desc = $repo["desc"]; - echo "$name$desc"; - echo ""; - $repo_base = gwvpmini_getConfigVal("repodir"); - $cmd = "git --git-dir=\"$repo_base/$name.git\" log -1 2>&1"; - error_log("CMD: $cmd"); - system("$cmd"); - echo ""; - echo ""; + $stat = $repo["status"]; + $llog = ""; + if($stat != 0) { + switch($stat) { + case 1: + $llog = "Repo Administratively Disabled"; + break; + case 2: + $llog = "Repo Cloning from remote"; + break; + } + } else { + + if($desc == "") $desc = "none"; + + $repo_base = gwvpmini_getConfigVal("repodir"); + $cmd = "git --git-dir=\"$repo_base/$name.git\" log --all -1 2> /dev/null"; + // error_log("CMD: $cmd"); + //system("$cmd"); + $fls = popen($cmd, "r"); + $tks = ""; + if($fls !== false) while(!feof($fls)) { + $tks .= fread($fls,1024); + } + + if($tks == "") { + $llog = "No Log Info Yet"; + } else $llog = $tks; + + } + echo "$name$desc$llog"; + } + echo ""; + } + gwvpmini_GitCreateRepoForm(); + + + $contreps = gwvpmini_GetContributedRepos($_SESSION["username"]); + + if($contreps !== false) { + echo "

Repos you contribute to

"; + echo ""; + foreach($contreps as $repo) { + $name = $repo["name"]; + $desc = $repo["desc"]; + $stat = $repo["status"]; + if($stat != 0) { + switch($stat) { + case 1: + $lastlog = "Repo Administratively Disabled"; + break; + case 2: + $lastlog = "Repo Cloning from remote"; + break; + } + } else { + $repo_base = gwvpmini_getConfigVal("repodir"); + $cmd = "git --git-dir=\"$repo_base/$name.git\" log --all -1 2> /dev/null"; + // error_log("CMD: $cmd"); + //system("$cmd"); + $fls = popen($cmd, "r"); + $tks = ""; + if($fls !== false) while(!feof($fls)) { + $tks .= fread($fls,1024); + } + + if($tks == "") { + $lastlog = "No Log Info Yet"; + } else $lastlog = $tks; + } + + $owner = gwvpmini_getUser(null, null, $repo["owner"]); + $repname = "$name"; + $repown = gwvpmini_HtmlGravatar($owner["email"], 30, "
")."".$owner["username"].""; + + + echo ""; } echo "
Repo NameOwnerRepo DescriptionLast Log
$repname$repown$desc$lastlog
"; } @@ -90,6 +161,9 @@ function gwvpmini_GitLogProvider() * * Or... should we instead just list every repo? */ + + global $BASE_URL; + echo "

Repo Activity

"; if(gwvpmini_isLoggedIn()) { $repos = gwvpmini_GetOwnedRepos($_SESSION["username"]); @@ -101,12 +175,23 @@ function gwvpmini_GitLogProvider() foreach($repos as $repo) { $name = $repo["name"]; $desc = $repo["desc"]; - echo "$name$desc"; + + if($desc == "") $desc = "-"; + echo "$name$desc"; echo ""; $repo_base = gwvpmini_getConfigVal("repodir"); - $cmd = "git --git-dir=\"$repo_base/$name.git\" log -1 2>&1"; - error_log("CMD: $cmd"); - system("$cmd"); + $cmd = "git --git-dir=\"$repo_base/$name.git\" log --all -1 2> /dev/null"; + // error_log("CMD: $cmd"); + //system("$cmd"); + $fls = popen($cmd, "r"); + $tks = ""; + if($fls !== false) while(!feof($fls)) { + $tks .= fread($fls,1024); + } + + if($tks == "") { + echo "No Log Info Yet"; + } else echo $tks; echo ""; echo ""; } @@ -122,15 +207,15 @@ function gwvpmini_GitCreateRepoForm() echo "
"; echo ""; echo ""; - echo ""; - echo ""; + echo ""; + echo ""; echo ""; + echo ""; + echo ""; echo ""; echo "
Create Repo
Repo Name
Repo Description
Repo NameName of your repo - letters, numbers _ and - only
Repo DescriptionDescription of your repo
Read Permissions"; echo ""; - echo "
The basic permissions for the initial repo creation
Clone FromEither a repo name (existing on this site) or a git url to clone from (blank for none)
"; echo "
"; @@ -144,6 +229,7 @@ function gwvpmini_RepoCreate() // TODO: check the stuff out // first reponame $inputcheck = true; + // remove a .git at the end if it was input $_REQUEST["reponame"] = preg_replace("/\.git$/", "", $_REQUEST["reponame"]); @@ -155,6 +241,47 @@ function gwvpmini_RepoCreate() $inputcheckerror = "Repo name contains invalid characters, repos can only contain a-z, A-Z, 0-9, _, - and ."; } + $clonefrom = false; + $fromremote = false; + if(isset($_REQUEST["clonefrom"])) { + if($_REQUEST["clonefrom"] != "") { + $clonefrom = $_REQUEST["clonefrom"]; + if(preg_match("/git.*:\/\/.*/", $clonefrom)>0) { + $fromremote = true; + } + if(preg_match("/http.*\:\/\//", $clonefrom)>0) $fromremote = true; + } + } + + if($clonefrom !== false && $fromremote == false) { + // check the local repo exists + $rn = gwvpmini_getRepo(null, $clonefrom, null); + $uid = $_SESSION["id"]; + + if($rn == false) { + gwvpmini_SendMessage("error", "local repo $clonefrom given as upstream clone, however $clonefrom doesnt exist on this site (or you cant read it unbake)"); + header("Location: $BASE_URL/repos"); + return; + } + + // resolve repo permissions on the read/clone + if(gwvpmini_GetRepoPerm($rn["id"], $uid) < 1) { + gwvpmini_SendMessage("error", "local repo $clonefrom given as upstream clone, however $clonefrom doesnt exist on this site (or you cant read it bake)"); + header("Location: $BASE_URL/repos"); + return; + } + } + + $defperms = "a"; + switch($_REQUEST["perms"]) { + case "perms-registered": + $defperms = "r"; + break; + case "perms-onlywrite": + $defperms = "x"; + break; + } + if(!$inputcheck) { gwvpmini_SendMessage("error", "$inputcheckerror"); header("Location: $BASE_URL/repos"); @@ -164,8 +291,9 @@ function gwvpmini_RepoCreate() gwvpmini_SendMessage("error", "Repo ".$_REQUEST["reponame"]." already exists"); header("Location: $BASE_URL/repos"); } else { - gwvpmini_createGitRepo($_REQUEST["reponame"], $_SESSION["id"], $_REQUEST["repodesc"]); - gwvpmini_SendMessage("info", "Repo ".$_REQUEST["reponame"]." has been created"); + if(gwvpmini_createGitRepo($_REQUEST["reponame"], $_SESSION["id"], $_REQUEST["repodesc"], $defperms, $clonefrom, $fromremote)) { + gwvpmini_SendMessage("info", "Repo ".$_REQUEST["reponame"]." has been created"); + } header("Location: $BASE_URL/repos"); } } else { @@ -181,4 +309,47 @@ function gwvpmini_HaveRepo($reponame) if(file_exists("$repo_base/$reponame.git")) return true; } + +function gwvpmini_RemoveRepo($rid) +{ + $repo_base = gwvpmini_getConfigVal("repodir"); + + $repdet = gwvpmini_getRepo(null, null, $rid); + + $rname = $repdet["name"]; + + // error_log("FROM PANTS:".print_r($repdet,true)." ----------- ".print_r($rname, true)); + + if($repdet != false && $rname != "") { + if(file_exists("$repo_base/$rname.git")) { + // recursive remove - frightening + if(gwvpmini_RecursiveDelete("$repo_base/$rname.git")) { + gwvpmini_RemoveRepoDB($rid); + } + } + } return false; +} + +function gwvpmini_RecursiveDelete($fpath) +{ + // error_log("RECURSEDETELE: ".$fpath); + if(is_file($fpath)){ + return @unlink($fpath); + } + elseif(is_dir($fpath)){ + $scan = glob(rtrim($fpath,'/').'/*'); + foreach($scan as $index=>$path){ + gwvpmini_RecursiveDelete($path); + } + return @rmdir($fpath); + } +} + +function gwvpmini_CompressCommitId($cid) +{ + $compressedcid = substr($cid, 0, 5)."...".substr($cid, strlen($cid)-5, strlen($cid)); + + return $compressedcid; +} + ?> \ No newline at end of file