summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStuart Henderson <sthen@cvs.openbsd.org>2008-07-04 15:03:46 +0000
committerStuart Henderson <sthen@cvs.openbsd.org>2008-07-04 15:03:46 +0000
commite3f75b28c8082bf59d6158ad6c9e9f235e82f823 (patch)
tree748cde4b47abb2c1673b05846dd8d401b3b4ae47
parent49ecb9a8910bceea832b38e7987aa56ce60114ad (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.813
-rw-r--r--usr.sbin/sysmerge/sysmerge.sh56
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