diff options
author | David Bremner <bremner@debian.org> | 2017-07-03 21:09:50 -0300 |
---|---|---|
committer | David Bremner <bremner@debian.org> | 2017-07-03 21:09:50 -0300 |
commit | abea1a643d0afd8fd56658048d46aac2c215dc63 (patch) | |
tree | d82dee8ad23b57e0507b9f4253657b53341108a7 /src/triggers/post-compile/update-gitweb-access-list |
Import gitolite3_3.6.7.orig.tar.gz
[dgit import orig gitolite3_3.6.7.orig.tar.gz]
Diffstat (limited to 'src/triggers/post-compile/update-gitweb-access-list')
-rwxr-xr-x | src/triggers/post-compile/update-gitweb-access-list | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/src/triggers/post-compile/update-gitweb-access-list b/src/triggers/post-compile/update-gitweb-access-list new file mode 100755 index 0000000..937226b --- /dev/null +++ b/src/triggers/post-compile/update-gitweb-access-list @@ -0,0 +1,35 @@ +#!/bin/sh + +# this is literally the simplest gitweb update possible. You are free to add +# whatever you want and contribute it back, as long as it is upward +# compatible. + +# ---------------------------------------------------------------------- +# delete the 'description' file that 'git init' created if this is run from +# the post-create trigger. However, note that POST_CREATE is also called from +# perms (since POST_CREATE doubles as eqvt of POST_COMPILE to propagate ad hoc +# permissions changes for wild repos) and then you should not delete it. +[ "$1" = "POST_CREATE" ] && [ "$4" != "perms" ] && rm -f $GL_REPO_BASE/$2.git/description 2>/dev/null + +# ---------------------------------------------------------------------- +# skip if arg-1 is POST_CREATE and no arg-3 (user name) exists; this means +# it's been triggered by a *normal* (not "wild") repo creation, which in turn +# means a POST_COMPILE should be following so there's no need to waste time +# running this once for each new repo +[ "$1" = "POST_CREATE" ] && [ -z "$3" ] && exit 0; + +plf=`gitolite query-rc GITWEB_PROJECTS_LIST` +[ -z "$plf" ] && plf=$HOME/projects.list +# since mktemp does not honor umask, we just use it to generate a temp +# filename (note: 'mktemp -u' on some systems, this gets close enough) +tmpfile=`mktemp $plf.tmp_XXXXXXXX` +rm -f $tmpfile; + +( + gitolite list-phy-repos | gitolite access % gitweb R any | grep -v DENIED + gitolite list-phy-repos | gitolite git-config -r % gitweb\\. +) | + cut -f1 | sort -u | sed -e 's/$/.git/' > $tmpfile + +[ -f $plf ] && perl -e "chmod ( ( (stat('$plf'))[2] & 07777 ), '$tmpfile')" +mv $tmpfile $plf |