update-server-info on git pushes and forks
authorChristian Weiske <cweiske@cweiske.de>
Mon, 7 Jul 2014 06:31:51 +0000 (08:31 +0200)
committerChristian Weiske <cweiske@cweiske.de>
Mon, 7 Jul 2014 06:31:51 +0000 (08:31 +0200)
src/phorkie/Forker.php
src/phorkie/Repository/Post.php
src/phorkie/Repository/Setup.php

index b4ab44968c5bf485f9154427e85e277ec40a2c90..da545a72c1eb590b4bedd98d9b35208800e3d438 100644 (file)
@@ -81,6 +81,10 @@ class Forker
         $rs = new Repository_Setup($new);
         $rs->afterInit();
 
+        //update info for dumb git HTTP transport
+        //the post-update hook should do that IMO, but does not somehow
+        $vc->getCommand('update-server-info')->execute();
+
         return $new;
     }
 
index cf07b73a571590dedf532ef63e6cbdec59ba969b..5a450b1aa0b446f63c82de95ae568fd09864583d 100644 (file)
@@ -152,6 +152,7 @@ class Repository_Post
                 ->setOption('message', "$notes")
                 ->execute();
             //update info for dumb git HTTP transport
+            //the post-update hook should do that IMO, but does not somehow
             $vc->getCommand('update-server-info')->execute();
 
             $bChanged = true;
index f5c9730f77c259ec0bb2f888cf3d49ac487c08a2..cc2fb28e80b734d51ba30d620a90995af12ae978 100644 (file)
@@ -27,6 +27,19 @@ class Repository_Setup
 
         $vc = $this->repo->getVc();
 
+        file_put_contents(
+            $this->repo->gitDir . '/hooks/post-update',
+            <<<CDE
+#!/bin/sh
+# Hook script to prepare a packed repository for use over dumb transports.
+
+echo foo > /tmp/foo
+exec git update-server-info
+
+CDE
+        );
+        chmod($this->repo->gitDir . '/hooks/post-update', 0755);
+
         //keep track of owner
         $vc->getCommand('config')
             ->addArgument('owner.name')