#!/bin/bash # sfsnapshot-upload - Snapshot upload script using sfsnapshotgit # Original author: Thomas Guyot-Sionnest <tguyot@gmail.com> # # This script uses sfsnapshotgit to update the snapshot is needed and upload # it to SourceForge. The branches to create snapshot from can be given as an # argument, otherwise the default is master. # Handle command errors (-e) and coder sleep deprivation issues (-u) set -eu trap 'echo "An error occurred in sfsnapshot-upload at line $LINENO"; exit 1' EXIT # This can be used to override the default in sfsnapshotgit: export SFSNAP_REPO=~/staging/nagiosplugins export SFSNAP_ORIGIN=origin export SFSNAP_DEST=~/staging/snapshot ## Some stuff that shouldn't change often... # The file we'll use to create the snapshot sfsnapshot=~/bin/sfsnapshotgit # Retention time for snapshots (in minutes), 0 for no retention. CLEAN_TIME=1440 # Where to place the generated files OUT_SERVER="tonvoon@frs.sourceforge.net" OUT_PATH="/home/groups/n/na/nagiosplug/htdocs/snapshot" # Links to always point to the master branch for backwards-compatibility COMPATLINKS="HEAD trunk-`date -u +%Y%m%d%H%M`" # And compatibility links to always delete except the last one COMPATCLEANUP="trunk-*" # If one or more argument is given, this is the branches to create the snapshots from if [ $# -eq 0 ] then HEADS='master' else HEADS=$@ fi # If we don't keep old snapshots we can clean up all links now if [ $CLEAN_TIME -eq 0 ] then find $SFSNAP_DEST -type l -name '*.gz' -delete fi for head in $HEADS ; do # This runs the actual snapshot code. It creates new snapshots if needed and always # return the current snapshot file (even if it wasn't modified). file=$($sfsnapshot $head) # Create main head link ln -sf $file $SFSNAP_DEST/nagios-plugins-$head.tar.gz # Keep links by branch name too if we keep old snapshots, so we can keep tracks of them if [ $CLEAN_TIME -gt 0 -a ! -e "$SFSNAP_DEST/nagios-plugins-$head-${file#nagios-plugins-}" ] then ln -s $file $SFSNAP_DEST/nagios-plugins-$head-${file#nagios-plugins-} fi # Cleanup and re-create backward-compatibility links if [ "$head" == "master" ] then for cclean in $COMPATCLEANUP do find $SFSNAP_DEST -type l -name "nagios-plugins-$cclean.tar.gz" -delete done for compat in $COMPATLINKS do ln -sf $file $SFSNAP_DEST/nagios-plugins-$compat.tar.gz done fi done cd $SFSNAP_DEST # Clean up links older than $CLEAN_TIME if needed if [ $CLEAN_TIME -gt 0 ] then find . -type l -name '*.gz' -mmin +$CLEAN_TIME -delete fi # Now clean up files that we don't need # 1. loop over actual snapshots for dest in `find . -type f -name '*.gz' |xargs -n 1 basename` do # 2. Loop over the list of linked-to files for current in `find . -type l -name '*.gz' |xargs -n 1 readlink | sort | uniq` do if [ "$current" == "$dest" ] then # File is being linked to - don't delete (continue first loop) continue 2 fi done # No link to this file, we can drop it rm -f $dest done # Create MD5 sum cat <<-END_README > README This is the latest snapshot of nagiosplug, consisting of the following head(s): $HEADS The nagios-plugins-<head>.tar.gz link will always point to the latest corresponding snapshot (nagios-plugins-<git-describe>.tar.gz). For backward-compatibility, the nagios-plugins-HEAD.tar.gz and nagios-plugins-trunk-<ts> point to their corresponding "master" head. The MD5SUM are: END_README md5sum *.gz | tee -a README > MD5SUM # Sync the files [ -n "$OUT_SERVER" ] && OUT_SERVER="$OUT_SERVER:" rsync -a --exclude=.htaccess --exclude=HEADER.html --delete "$SFSNAP_DEST/" "$OUT_SERVER$OUT_PATH" trap - EXIT