summaryrefslogtreecommitdiffstats
path: root/mga-move-update-nosync
diff options
context:
space:
mode:
Diffstat (limited to 'mga-move-update-nosync')
-rwxr-xr-xmga-move-update-nosync114
1 files changed, 114 insertions, 0 deletions
diff --git a/mga-move-update-nosync b/mga-move-update-nosync
new file mode 100755
index 0000000..ad0782c
--- /dev/null
+++ b/mga-move-update-nosync
@@ -0,0 +1,114 @@
+#!/bin/sh
+
+. /usr/share/mgatools/functions
+
+if [ $# != 3 ]
+then
+ echo 'Usage: mga-move-update distrorelease section srcname' >&2
+ exit 1
+fi
+
+distrorelease="$1"
+section="$2"
+srcname="$3"
+
+if ! inlist "$distrorelease" "$distroreleases"
+then
+ echo "Incorrect distrorelease $distrorelease" >&2
+ exit 1
+fi
+
+if ! inlist "$section" "$distrosections"
+then
+ echo "Incorrect section $section" >&2
+ exit 1
+fi
+
+for file in "$distribdir/$distrorelease/SRPMS/$section/updates_testing/"*.rpm
+do
+ fname=$(rpm -qp --qf '%{NAME}' "$file")
+ if [ a"$fname" = a"$srcname" ]
+ then
+ srcpkg=$(basename "$file")
+ break
+ fi
+done
+
+if [ -z $srcpkg ]
+then
+ echo "The package $srcname could not be found in $distrorelease/$section/updates_testing repository." >&2
+ exit 2
+fi
+
+# safety check
+echo " This SRPM (and matching binarys) will be moved from updates_testing to updates:" >&2
+echo " " >&2
+echo " $srcpkg" >&2
+echo " " >&2
+read -p " Are you sure ? " yn >&2
+
+case $yn in
+ [Yy]* ) continue;;
+ * ) exit;;
+esac
+
+function movepkg()
+{
+ srcdir="$1"
+ destdir="$2"
+ srcpkg="$3"
+ output="$4"
+
+ for file in "$srcdir/"*.rpm
+
+ do
+ fname=$(rpm -qp --qf '%{SOURCERPM}' "$file")
+ if [ a"$fname" = a"$srcpkg" ]
+ then
+ $dryrun mv -v -f "$file" "$destdir" >> "$output"
+ echo "$(basename $file)"
+ fi
+ done
+}
+
+#function post()
+#{
+# for arch in $arches
+# do
+# update_hdlist "$distribdir/$distrorelease/$arch/media/$section/updates_testing"
+# update_hdlist "$distribdir/$distrorelease/$arch/media/$section/updates"
+# update_hdlist "$distribdir/$distrorelease/$arch/media/debug/$section/updates_testing"
+# update_hdlist "$distribdir/$distrorelease/$arch/media/debug/$section/updates"
+# done
+# update_hdlist "$distribdir/$distrorelease/SRPMS/$section/updates_testing"
+# update_hdlist "$distribdir/$distrorelease/SRPMS/$section/updates"
+# update_common_MD5SUM $distrorelease
+# mirror_repository $distrorelease
+#}
+
+echo ""
+echo "moving binary and source rpms:"
+mailcontent=$(mktemp)
+for arch in $arches
+do
+ echo ""
+ echo "$arch:"
+ movepkg "$distribdir/$distrorelease/$arch/media/$section/updates_testing" "$distribdir/$distrorelease/$arch/media/$section/updates/" "$srcpkg" "$mailcontent"
+ movepkg "$distribdir/$distrorelease/$arch/media/debug/$section/updates_testing" "$distribdir/$distrorelease/$arch/media/debug/$section/updates/" "$srcpkg" "$mailcontent"
+done
+echo ""
+echo "SRPMS:"
+echo "$srcpkg"
+echo ""
+$dryrun mv -v -f "$distribdir/$distrorelease/SRPMS/$section/updates_testing/$srcpkg" "$distribdir/$distrorelease/SRPMS/$section/updates/" >> "$output"
+
+if [ -n "$dryrun" ]
+then
+ cat "$mailcontent"
+else
+ /usr/bin/mailx -s "mga-move-update $distrorelease $section $srcname" -S "from=$moveupdate_mailfrom" "$moveupdate_mailto" < "$mailcontent"
+#
+# (tmb) dont do post before all rpms are moved, call update_hdlists manually
+# post
+fi
+rm -f "$mailcontent"