diff options
author | Stuart Henderson <sthen@cvs.openbsd.org> | 2008-07-04 15:03:46 +0000 |
---|---|---|
committer | Stuart Henderson <sthen@cvs.openbsd.org> | 2008-07-04 15:03:46 +0000 |
commit | e3f75b28c8082bf59d6158ad6c9e9f235e82f823 (patch) | |
tree | 748cde4b47abb2c1673b05846dd8d401b3b4ae47 | |
parent | 49ecb9a8910bceea832b38e7987aa56ce60114ad (diff) |
Teach sysmerge to retrieve {etc,xetc}*.tgz files from FTP/HTTP
paths using ftp(1). Thanks ajacoutot and jmc for suggestions.
ok ajacoutot jmc, no objection deraadt
-rw-r--r-- | usr.sbin/sysmerge/sysmerge.8 | 13 | ||||
-rw-r--r-- | usr.sbin/sysmerge/sysmerge.sh | 56 |
2 files changed, 55 insertions, 14 deletions
diff --git a/usr.sbin/sysmerge/sysmerge.8 b/usr.sbin/sysmerge/sysmerge.8 index 55a8eaf746c..130ebcd476e 100644 --- a/usr.sbin/sysmerge/sysmerge.8 +++ b/usr.sbin/sysmerge/sysmerge.8 @@ -1,4 +1,4 @@ -.\" $OpenBSD: sysmerge.8,v 1.9 2008/07/04 10:23:56 jmc Exp $ +.\" $OpenBSD: sysmerge.8,v 1.10 2008/07/04 15:03:45 sthen Exp $ .\" .\" Copyright (c) 2008 Antoine Jacoutot <ajacoutot@openbsd.org> .\" @@ -163,12 +163,13 @@ later manual processing. Specify a path to an .Ox top src directory or an etcXX.tgz tarball. +A tarball path specified as an FTP or HTTP URL will be passed +to ${FETCH_CMD}. .It Fl x Ar xetcXX.tgz Specify a path to an xetcXX.tgz tarball. -If this option is specified, it will add -.Xr X 7 -configuration files to the comparison. +A tarball path specified as an FTP or HTTP URL will be passed +to ${FETCH_CMD}. .El .Sh ENVIRONMENT .Bl -tag -width "DESTDIRXXX" @@ -176,6 +177,10 @@ configuration files to the comparison. Directory in which to merge and install files. If unset, this defaults to .Pa / . +.It Ev FETCH_CMD +Command used to fetch remote files. +Defaults to +.Xr ftp 1 . .It Ev TMPDIR Directory in which the work directory is created. If unset, this defaults to diff --git a/usr.sbin/sysmerge/sysmerge.sh b/usr.sbin/sysmerge/sysmerge.sh index 1a340dda99f..768f7de2d69 100644 --- a/usr.sbin/sysmerge/sysmerge.sh +++ b/usr.sbin/sysmerge/sysmerge.sh @@ -1,6 +1,6 @@ #!/bin/sh - # -# $OpenBSD: sysmerge.sh,v 1.15 2008/06/13 23:56:48 ajacoutot Exp $ +# $OpenBSD: sysmerge.sh,v 1.16 2008/07/04 15:03:45 sthen Exp $ # # This script is based on the FreeBSD mergemaster script, written by # Douglas Barton <DougB@FreeBSD.org> @@ -29,14 +29,19 @@ PATH="/bin:/usr/bin:/sbin:/usr/sbin" PAGER="${PAGER:=/usr/bin/more}" SWIDTH=`stty size | awk '{w=$2} END {if (w==0) {w=80} print w}'` +WRKDIR=`mktemp -d -p /var/tmp sysmerge.XXXXX` || exit 1 +trap "rm -rf ${WRKDIR}; exit 1" 1 2 3 13 15 -do_pre() { - if [ `id -u` -ne 0 ]; then - echo " *** ERROR: Need root privilege to run this script" - exit 1 +if [ -z "${FETCH_CMD}" ]; then + if [ -z "${FTP_KEEPALIVE}" ]; then + FTP_KEEPALIVE=0 fi + FETCH_CMD="/usr/bin/ftp -V -m -k ${FTP_KEEPALIVE}" +fi + +do_pre() { if [ -z "${SRCDIR}" -a -z "${TGZ}" -a -z "${XTGZ}" ]; then if [ -f "/usr/src/etc/Makefile" ]; then SRCDIR=/usr/src @@ -46,15 +51,24 @@ do_pre() { fi fi - WRKDIR=`mktemp -d -p /var/tmp sysmerge.XXXXX` || exit 1 TEMPROOT="${WRKDIR}/temproot" BKPDIR="${WRKDIR}/backups" - trap "rm -rf ${WRKDIR}; exit 1" 1 2 3 13 15 - if [ -z "${BATCHMODE}" -a -z "${AUTOMODE}" ]; then echo "\n===> Running ${0##*/} with the following settings:\n" - echo " source(s): ${SRCDIR}${TGZ} ${XTGZ}" + if [ -n "${TGZURL}" ]; then + echo " etc source: ${TGZURL}" + echo " (fetched in ${TGZ})" + else + [ -n "${TGZ}" ] && echo " etc source: ${TGZ}" + fi + if [ -n "${XTGZURL}" ]; then + echo " xetc source: ${XTGZURL}" + echo " (fetched in ${XTGZ})" + else + [ -n "${XTGZ}" ] && echo " etc source: ${XTGZ}" + fi + echo "" echo " base work directory: ${WRKDIR}" echo " temp root directory: ${TEMPROOT}" echo " backup directory: ${BKPDIR}" @@ -66,7 +80,7 @@ do_pre() { echo "" ;; *) - rmdir ${WRKDIR} 2> /dev/null + rm -rf ${WRKDIR} 2> /dev/null exit 1 ;; esac @@ -432,6 +446,12 @@ if [ $? -ne 0 ]; then echo "usage: ${0##*/} [-ab] [-s src | etcXX.tgz] [-x xetcXX.tgz]" >&2 exit 1 fi + +if [ `id -u` -ne 0 ]; then + echo " *** ERROR: Need root privilege to run this script" + exit 1 +fi + set -- ${ARGS} while [ $# -ne 0 ] do @@ -451,6 +471,14 @@ do awk -F/ '{print $NF}' | \ grep '^etc[0-9][0-9]\.tgz$' > /dev/null 2>&1 ; then TGZ=${WHERE} + elif echo ${WHERE} | \ + grep -qE '^(http|ftp)://.*/etc[0-9][0-9]\.tgz$'; then + TGZ=${WRKDIR}/etc.tgz + TGZURL="${WHERE}" + if ! ${FETCH_CMD} -o ${TGZ} ${TGZURL}; then + echo " *** ERROR: Could not retrieve ${TGZURL}" + exit 1 + fi else echo " *** ERROR: ${WHERE} is not a path to src nor etcXX.tgz" exit 1 @@ -463,6 +491,14 @@ do awk -F/ '{print $NF}' | \ grep '^xetc[0-9][0-9]\.tgz$' > /dev/null 2>&1 ; then XTGZ=${WHERE} + elif echo ${WHERE} | \ + grep -qE '^(http|ftp)://.*/xetc[0-9][0-9]\.tgz$'; then + XTGZ=${WRKDIR}/xetc.tgz + XTGZURL="${WHERE}" + if ! ${FETCH_CMD} -o ${XTGZ} ${XTGZURL}; then + echo " *** ERROR: Could not retrieve ${XTGZURL}" + exit 1 + fi else echo " *** ERROR: ${WHERE} is not a path to xetcXX.tgz" exit 1 |