7 * #repo/hooks/post-receive
8 * /usr/bin/php {PATH TO APPLICATION}/index.php Hook/git post >> /tmp/githooklog
16 /* For licensing and copyright terms, see the file named LICENSE */
19 // git-commit-hook what [mtrackconfig] > /tmp/gitlog
20 // the cwd is the repo path
21 // a list of "oldrev newrev refname" lines is presented to us on stdin
24 require_once 'MTrackWeb.php';
26 class MTrackWeb_Hook_git extends MTrackWeb
30 if (!HTML_FlexyFramework::get()->cli) {
41 $repo = DB_DataObject::factory('mtrack_repos');
42 $repo->repopath = getcwd();
43 if (!$repo->find(true)) {
44 $this->addEvent("HOOKERROR", false, "invalid repo:". getcwd() );
45 die("INVALID REPO" . getcwd() );
49 require_once 'MTrack/SCM/Git/CommitHookBridge.php';
51 $bridge = new MTrack_SCM_Git_CommitHookBridge($repo);
53 die("work out user?");
55 // WTF is this for.. it the hook should be telling who the user is.
56 $author = 'www-data';//MTrackAuth::whoami();
57 $author = mtrack_canon_username($author);
58 MTrackAuth::su($author);
60 $checker = new MTrackCommitChecker($repo);
65 $checker->preCommit($bridge);
69 $checker->postCommit($bridge);
77 } catch (Exception $e) {
79 fwrite(STDERR, "\n" . $e->getMessage() .
81 $e->getTraceAsString() .
82 "\n\n ** Commit failed [$action]\n");