diff options
author | Nicolás Reynolds <fauno@kiwwwi.com.ar> | 2011-11-23 13:19:35 -0300 |
---|---|---|
committer | Nicolás Reynolds <fauno@kiwwwi.com.ar> | 2011-11-23 13:19:35 -0300 |
commit | 51e733fdb525e1c1e9392aa4c3a0b882a6433ad4 (patch) | |
tree | b7cf9c75bbfc86b6fde2e7eddcacc3d1117f7ba1 /db-cleanup | |
parent | 9ef417865ef8b102875d42d4cb8ebe277de4ec01 (diff) |
Cleanup script + New config vars
Diffstat (limited to 'db-cleanup')
-rwxr-xr-x | db-cleanup | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/db-cleanup b/db-cleanup new file mode 100755 index 0000000..0c093c2 --- /dev/null +++ b/db-cleanup @@ -0,0 +1,63 @@ +#!/bin/bash +# Syncs pools against themselves using database contents as filter to cleanup +# them up +# License: GPLv3 + +# Principles +# * Get repos dbs contents +# * Make them a include list +# * Rsync pools against themselves removing excluded files +# * Instant cleanup! + +trap_exit() { + echo + error "$@" + exit 1 +} + +source $(dirname $0)/config +source $(dirname $0)/local_config +source $(dirname $0)/libremessages + +# From makepkg +set -E + +trap 'trap_exit "$(gettext "TERM signal caught. Exiting...")"' TERM HUP QUIT +trap 'trap_exit "$(gettext "Aborted by user! Exiting...")"' INT +trap 'trap_exit "$(gettext "An unknown error has occurred. Exiting...")"' ERR + +(( CLEANUP_DRYRUN )) && EXTRAFLAGS+=" --dry-run" + +for _repo in ${ARCHREPOS[@]}; do + for _arch in ${ARCHARCHES[@]}; do + msg "Getting ${_repo}-${_arch} database" + + dbfile="${FTP_BASE}/${_repo}/os/${_arch}/${_repo}${DBEXT}" + + if [ ! -r "${dbfile}" ]; then + warning "Not found" + continue + fi + +# Echo the contents into a filter file + bsdtar tf "${dbfile}" | \ + cut -d'/' -f1 | \ + sort -u | \ + sed "s|$|*|" >> /tmp/$0.$PID.filter + + done +done + +msg "Removing old files:" + +for POOL in ${PKGPOOLS[@]} ${SRCPOOLS[@]}; do + msg2 "${POOL}" + + rsync ${EXTRAFLAGS} -va --delete-excluded \ + --include-from="${dbfile}" \ + --exclude="*" \ + ${FTP_BASE}/${POOL}/ \ + ${FTP_BASE}/${POOL}/ +done + +exit $? |