From 2b442ff177751c5ea17e792c10e6d50d7b922b08 Mon Sep 17 00:00:00 2001 From: Holger Weiss Date: Sat, 7 Nov 2009 10:40:22 +0100 Subject: [PATCH] Git commit notifications via post-receive hook Now that we moved our Git repositories to SourceForge, we don't need to maintain local clones for generating commit notifications anymore, as SourceForge provides shell access to the repositories. Instead, we now run git-notify as a post-receive hook on the SourceForge server. Actually, we use a wrapper which executes git-notify with the desired options and which makes it easy to add other post-receive hooks in the future. --- tools/git-post-receive-hook | 23 +++++++++ tools/git-update-mirror | 94 ------------------------------------- 2 files changed, 23 insertions(+), 94 deletions(-) create mode 100755 tools/git-post-receive-hook delete mode 100755 tools/git-update-mirror diff --git a/tools/git-post-receive-hook b/tools/git-post-receive-hook new file mode 100755 index 0000000..70d259e --- /dev/null +++ b/tools/git-post-receive-hook @@ -0,0 +1,23 @@ +#!/bin/sh + +prefix="${0%/*}/notifications" # $GIT_DIR/hooks/notifications +recipient='Nagios Plugin Commits ' +maxcommits=100 +maxdiffsize=$((300 * 1024)) +gitweburl='http://nagiosplug.git.sf.net/git/gitweb.cgi?p=nagiosplug' +gitnotify="$prefix/git-notify.pl" +statefile="$prefix/git-notify.dat" + +exec "$gitnotify" \ + -m "$recipient" \ + -n "$maxcommits" \ + -s "$maxdiffsize" \ + -t "$statefile" \ + -u "$gitweburl" \ + -A \ + -C \ + -H \ + -S \ + -T \ + -X \ + -z diff --git a/tools/git-update-mirror b/tools/git-update-mirror deleted file mode 100755 index e258a12..0000000 --- a/tools/git-update-mirror +++ /dev/null @@ -1,94 +0,0 @@ -#!/bin/sh -# -# Copyright (c) 2009 Nagios Plugins Development Team -# -# This program is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# This program is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with this program. If not, see . - -set -e -set -u - -prefix='/home/git' - -PATH="$prefix/opt/git/bin:/bin:/usr/bin" -export PATH - -gitnotify="$prefix/libexec/git-notify" -recipient='Nagios Plugins Commit List ' -maxcommits=100 -maxdiffsize=$((300 * 1024)) -gitweburl='http://repo.or.cz/w' -tempprefix='/dev/shm' -fourtyzeros=$(printf '%.40u' 0) -myself=${0##*/} - -checkrefs() -{ - turn=$1 - - git show-ref | while read object ref - do - refdir="$tempdir/${ref%/*}" - reffile="$tempdir/$ref" - - if [ $turn -eq 2 -a -f "$reffile" ] \ - && grep "^1 $object$" "$reffile" >'/dev/null' - then # The ref has not been modified. - rm -f "$reffile" - else - mkdir -p "$refdir" - echo "$turn $object" >>"$reffile" - fi - done -} - -if [ $# -lt 1 ] -then - echo >&2 "Usage: $myself ..." - exit 1 -fi - -tempdir=$(mktemp -d "$tempprefix/$myself.XXXXXX") -tempfile=$(mktemp "$tempprefix/$myself.XXXXXX") -trap 'rm -rf "$tempdir" "$tempfile"' EXIT - -for repository in "$@" -do - cd "$repository" - - checkrefs 1 - if ! git remote update --prune >"$tempfile" 2>&1 - then - cat >&2 "$tempfile" - exit 1 - fi - git fetch --quiet --tags - checkrefs 2 - - find "$tempdir" -type 'f' -print | while read reffile - do - ref=${reffile#$tempdir/} - old=$(awk '$1 == "1" { print $2; exit }' "$reffile") - new=$(awk '$1 == "2" { print $2; exit }' "$reffile") - old=${old:-$fourtyzeros} - new=${new:-$fourtyzeros} - - echo "$old" "$new" "$ref" - done | $gitnotify \ - -m "$recipient" \ - -n "$maxcommits" \ - -s "$maxdiffsize" \ - -u "$gitweburl" - - cd "$OLDPWD" -done -- 2.30.2