diff options
author | Aaron Griffin <aaronmgriffin@gmail.com> | 2009-07-20 18:51:04 -0400 |
---|---|---|
committer | Aaron Griffin <aaronmgriffin@gmail.com> | 2009-07-20 18:51:04 -0400 |
commit | 754d26d772570d02c878ab6afc3dc5f75e17e373 (patch) | |
tree | 71468e494307d1bce791edf7b09896483328fd15 | |
parent | 755ba2fd1198272914e540806e9bfb94416da0ca (diff) |
ftpdir-cleanup: Fixes for 'any' support
* Break out ftppath, base it on ftbpath_base
* Only check ARCHINDEPFILES if the any dir exists
* Attempt to restore symlinks before moving 'any' files out of the way
Signed-off-by: Aaron Griffin <aaronmgriffin@gmail.com>
-rwxr-xr-x | misc-scripts/ftpdir-cleanup | 50 |
1 files changed, 40 insertions, 10 deletions
diff --git a/misc-scripts/ftpdir-cleanup b/misc-scripts/ftpdir-cleanup index 9bac030..7de64b9 100755 --- a/misc-scripts/ftpdir-cleanup +++ b/misc-scripts/ftpdir-cleanup @@ -10,10 +10,11 @@ arch=$2 dest=$3 ##### Arch specific stuff. TODO make this configurable ##### -ftppath="/srv/ftp/$reponame/os/$arch/" ftppath_base="/srv/ftp/$reponame/os" ############################################################ +ftppath="$ftppath_base/$arch" + if [ ! -d "$ftppath" ]; then echo "FTP path '$ftppath' does not exist" exit 1 @@ -32,7 +33,6 @@ getpkgname() { tmp=${1##*/} tmp=${tmp%$PKGEXT} tmp=${tmp%-$arch} - tmp=${tmp%-any} echo ${tmp%-*-*} } @@ -41,8 +41,7 @@ getpkgname_ver() { tmp=${1##*/} tmp=${tmp%$PKGEXT} - tmp=${tmp%-$arch} - echo ${tmp%-any} + echo ${tmp%-$arch} } MISSINGFILES="" @@ -82,12 +81,14 @@ for pkg in *$arch$PKGEXT; do EXTRAFILES="$EXTRAFILES $pkg" done -cd "$ftppath_base/any" -for pkg in *$PKGEXT; do - if [ ! -h $ftppath_base/i686/$pkg -a ! -h $ftppath_base/x86_64/$pkg ]; then - ARCHINDEPFILES="$ARCHINDEPFILES $pkg" - fi -done +if [ -d "$ftppath_base/any" ]; then + cd "$ftppath_base/any" + for pkg in *$PKGEXT; do + if [ ! -h $ftppath_base/i686/$pkg -a ! -h $ftppath_base/x86_64/$pkg ]; then + ARCHINDEPFILES="$ARCHINDEPFILES $pkg" + fi + done +fi cd "$ftppath" rm -rf ${TMPDIR} @@ -97,6 +98,35 @@ if [ -z "$DELETEFILES$MISSINGFILES$EXTRAFILES$ARCHINDEPFILES" ]; then exit 0 fi +#Do a quick check. If we have a MISSINGFILE and an ARCHINDEPFILE of the same +#name to remove, then let's restore the symlink. + +archfiles="$ARCHINDEPFILES" +ARCHINDEPFILES="" +for af in $archfiles; do + af_satisfied=0 + for mf in $MISSINGFILES; do + if [ "${af}" = "${mf}" ]; then + ln -s "${ftppath_base}/any/${af}" "${ftppath}" + af_satisfied=1 + fi + + done + if [ $af_satisfied -eq 0 ]; then + ARCHINDEPFILES="${ARCHINDEPFILES} ${af}" + fi +done +#rescan missing files now +missfiles="$MISSINGFILES" +MISSINGFILES="" +for mf in $missfiles; do + if [ ! -e "${ftppath}/${mf}" ]; then + MISSINGFILES="${MISSINGFILES} ${mf}" + else + echo "Missing file has been restored: $mf" + fi +done + echo "Scan complete for $reponame ($arch) at ${ftppath}" if [ -n "$DELETEFILES" ]; then |