if(file_exists("$WEB_ROOT_FS/../gwvpmini/gwvpmini.php")) require_once("$WEB_ROOT_FS/../gwvpmini/gwvpmini.php");
else if(file_exists("/usr/share/gwvpmini/lib/gwvpmini/gwvpmini.php")) require_once("/usr/share/gwvpmini/lib/gwvpmini/gwvpmini.php");
-if(isset($argv["1"])) {
- switch($argv["1"]) {
+
+echo "ARGS: ".print_r($argv,true);
+echo "CWD: ".getcwd()."\n";
+
+if(isset($argv["3"])) {
+ switch($argv["3"]) {
case "update":
gwvpcmdtool_UpdateHook();
break;
return;
+/*
+ * remote: ARGS: Array
+remote: (
+remote: [0] => /nfs/export/src/local/eclipse-workspace/gwvp-mini/bin/gwvpminicmdtool.php
+remote: [1] => asfd
+remote: [2] => admin
+remote: [3] => pre-receive
+remote: [4] => fc781c4ef5bfeae8ec01bb527db1b6ce6f65d03c
+remote: [5] => 7d45d43f04276fc9addb77ba8bf753329eab018d
+remote: [6] => refs/heads/master
+remote: )
+remote: ARGS: Array
+remote: (
+remote: [0] => /nfs/export/src/local/eclipse-workspace/gwvp-mini/bin/gwvpminicmdtool.php
+remote: [1] => asfd
+remote: [2] => admin
+remote: [3] => pre-receive
+remote: [4] => /nfs/export/src/local/eclipse-workspace/gwvp-mini/bin/gwvpminicmdtool.php
+remote: [5] => asfd
+remote: [6] => admin
+remote: [7] => update
+remote: [8] => refs/heads/master
+remote: [9] => fc781c4ef5bfeae8ec01bb527db1b6ce6f65d03c
+remote: [10] => 7d45d43f04276fc9addb77ba8bf753329eab018d
+
+ */
+
function gwvpcmdtool_Usage()
{
global $argv;
- echo "Usage: ".$argv[0]."\n";
- echo "\tupdatehook <user> <ref> <firstupdate> <lastupdate>\n";
+ echo "Usage: ".$argv[0]." this tool should not be called directly by user\n";
}
{
global $argv;
//echo "got ".$argv[2].", ".$argv[3].", ".$argv[4]."\n";
- if(preg_match("/^000000+$/", $argv[3])) {
+ if(preg_match("/^000000+$/", $argv[5])) {
// createion of tag or branch
- $vals = explode("/", $argv[2]);
+ $vals = explode("/", $argv[4]);
$type = "unknowncreate";
- if($vals == "heads") $type = "branchcreate";
- if($vals == "tags") $type = "tagcreate";
- gwvpmini_AddActivityLog("$type", "1", "1", $argv[4], "somelogs");
+ if($vals[1] == "heads") $type = "branchcreate";
+ if($vals[1] == "tags") $type = "tagcreate";
+
+ //gwvpmini_AddRefActivityForRepo();
+ gwvpmini_AddRefActivityForRepo($argv[1], $argv[2], $vals[2], $type);
+ echo "REFSUP: ".$vals[2].", $type\n";\r
+
}
//gwvpmini_AddActivityLog($type, $userid, $repoid, $commitid, $commitlog)
+ //gwvpmini_AddRefActivityForRepo($reponame, $byusername, $branchname, $acttype="branch")
}
// pre-receive logs all commit info
//echo "got from prereceive ".$argv[2].", ".$argv[3].", ".$argv[4]."\n";\r
- //passthru("git rev-list --reverse ".$argv[3]." --not --all ");
+ $lns = 0;
+ $ref = $argv[6];
+
+ $regspl = explode("/", $ref);
+ $branch = $regspl[2];
+
+ $fp = popen("git rev-list --reverse ".$argv[5]." --not --all ", "r");
+ if($fp) while(!feof($fp)) {
+ $line = trim(fgets($fp));
+ if($line != "") {
+ $cdd[$lns] = gwvpcmdtool_getCommitIdDetails($line);
+ echo "FORCID $line we get \n".print_r($cdd[$lns], true);
+ gwvpmini_AddCommitActivityForRepo($argv[1], $argv[2], $line, $cdd[$lns]["log"], $branch);
+ $lns++;
+ }
+ }
+
+
+ //echo "Called git rev-list --reverse ".$argv[5]." --not --all\n\n";
+ //gwvpmini_AddCommitActivityForRepo($reponame, $byusername, $commitid, $desc)
+}
+
+function gwvpcmdtool_getCommitIdDetails($commitid)
+{
+ $rs = popen("git log --pretty=format:\"%at%n%ce%n%an%n%s\" $commitid -1 2> /dev/null", "r");
+ $ret = array();\r
+ if($rs) {\r
+ $ret["date"] = trim(fgets($rs));\r
+ $ret["email"] = trim(fgets($rs));\r
+ $ret["fullname"] = trim(fgets($rs));
+ $ret["log"] = "";\r
+ while(!feof($rs)) {\r
+ $ret["log"] .= fread($rs, 8192);\r
+ }\r
+ } else {
+ $ret = false;
+ }
+
+ return $ret;
}
?>
\ No newline at end of file