Annotation of openbsd/update_openbsd/update_openbsd, Revision 1.110
1.1 andrew 1: #!/bin/sh
1.110 ! andrew 2: # $AFresh1: update_openbsd,v 1.109 2018/02/08 19:08:01 andrew Exp $
1.94 andrew 3: #
1.41 andrew 4: # Copyright (c) 2012 Andrew Fresh <andrew@afresh1.com>
5: #
6: # Permission to use, copy, modify, and distribute this software for any
7: # purpose with or without fee is hereby granted, provided that the above
8: # copyright notice and this permission notice appear in all copies.
9: #
10: # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11: # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12: # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13: # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14: # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15: # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16: # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17: #
1.7 andrew 18:
1.2 andrew 19: installed_sets() {
1.5 andrew 20: local misc=/usr/share/doc/README
1.63 andrew 21: local man=/usr/share/man/man1/intro.1
1.5 andrew 22: local comp=/usr/bin/cc
23: local game=/usr/games/
24: local xbase=/usr/X11R6/
25: local xetc=/etc/X11/xinit/xinitrc
26: local xfont=/usr/X11R6/lib/X11/fonts
27: local xserv=/usr/X11R6/bin/X
28: local xshare=/usr/X11R6/bin/startx
29:
1.75 andrew 30: local _nv=`echo $NEW_VER | sed -e 's/\.//'`
1.5 andrew 31: local _c _d _e
32: echo -n base
1.75 andrew 33: [ $_nv -lt 57 ] && echo -n ' etc'
1.3 andrew 34: for _d in misc man comp game xbase xetc xfont xserv xshare; do
1.75 andrew 35: [ $_d = xetc -a $_nv -ge 57 ] && continue
1.3 andrew 36: eval _e=\$${_d}
37: _c=`ls $_e 2> /dev/null | wc -l`
38: #echo $_c $_d $_e
39: if [ $_c -ne 0 ]; then
1.5 andrew 40: echo -n " $_d"
1.2 andrew 41: fi
42: done
1.19 andrew 43:
1.34 andrew 44: sendmail -d0.1 --badoption </dev/null 2>/dev/null | grep -q SASL
1.94 andrew 45: if [ $? == 0 ]; then
1.19 andrew 46: echo -n ' sendmail-smtp_auth'
47: fi
1.2 andrew 48: }
1.7 andrew 49:
1.39 andrew 50: kernel_file_version() {
51: echo exit | config -e $1 | grep -A1 ^OpenBSD
52: #what $1 | sed -ne 's/[[:blank:]]\{1,\}//p'
53: }
54:
1.105 andrew 55: kernel_is_multiprocessor() {
56: printf "find cpu*\nexit\n" | config -e $1 2>/dev/null | grep -q "cpu\* at "
57: }
58:
1.16 andrew 59: version_in() {
1.10 andrew 60: local _proto=${FTP%%://*}
1.16 andrew 61: local _file
1.10 andrew 62:
63: if [ X"ftp" == X"${_proto}" ]; then
1.16 andrew 64: local _list=`echo "ls base*.tgz" | ${FTP_CMD} ${FTP}/`
65: _file=`echo ${_list} | awk '/base[0-9][0-9].tgz/ { print $9 }'`
1.15 andrew 66:
1.87 andrew 67: elif [ X"http" == X"${_proto}" -o X"https" == X"${_proto}" ]; then
1.96 andrew 68: _file=`${FTP_CMD} -V -o - ${FTP}/index.txt |
69: sed -ne 's/.*\(base[0-9][0-9].tgz\).*/\1/p'`
1.15 andrew 70:
71: elif [ X"scp" == X"${_proto}" ]; then
72: echo SCP is not yet supported >&2
73: return 2
74:
1.96 andrew 75: else
1.10 andrew 76: echo Unsupported FTP ${FTP} >&2
1.12 andrew 77: return 2
1.15 andrew 78:
1.10 andrew 79: fi
1.16 andrew 80:
81: local _v=${_file##*base}
82: _v=${_v%.tgz*}
83: echo $_v
1.10 andrew 84: }
1.2 andrew 85:
1.98 andrew 86: set_boot_device() {
87: BOOT_DEVICE=$( df -nP /bsd | sed -ne 's! .*/$!!p' )
1.97 andrew 88:
1.98 andrew 89: root_disk=$( echo $BOOT_DEVICE |
1.97 andrew 90: sed -e 's,/dev/\([a-z]*[0-9]\)[a-z].*,\1,' )
91: msdos_partition=$(
92: fdisk $root_disk | grep -q '^*.*FAT32' \
93: && \
94: disklabel $root_disk | sed -ne 's/:.*MSDOS//p' | tr -d ' '
95: )
96:
97: [ "$msdos_partition" ] &&
1.98 andrew 98: BOOT_DEVICE="/dev/$root_disk$msdos_partition"
1.97 andrew 99: }
100:
1.99 andrew 101: boot_device_mounted=""
102: mount_boot_device() {
1.103 andrew 103: [ "$boot_device_mounted" ] && return
1.109 andrew 104: [ "$BOOT_DEVICE" ] || return
1.99 andrew 105:
106: local default_mount=$( df -lnP /bsd | sed -ne 's!/dev/.* !!p' )
107: local boot_mount=$( mount |
108: sed -ne "s!^$BOOT_DEVICE on \([^ ]*\).*!\1!p" )
109:
110: if [ ! "$boot_mount" ]; then
1.101 andrew 111: mount $BOOT_DEVICE /mnt
1.102 andrew 112: boot_device_mounted=1
1.101 andrew 113: KERNEL_ROOT=/mnt
1.99 andrew 114: elif [ "$boot_mount" != "$default_mount" ]; then
1.101 andrew 115: KERNEL_ROOT=$boot_mount/
1.99 andrew 116: else
1.101 andrew 117: KERNEL_ROOT=${default_mount%/}/
1.99 andrew 118: fi
119: }
120:
121: umount_boot_device() {
1.101 andrew 122: [ "$boot_device_mounted" ] && umount $BOOT_DEVICE
1.99 andrew 123: boot_device_mounted=""
124: }
125:
1.104 andrew 126: find_boot_kernel() {
127: local _k=$( ( \
128: echo bsd; \
129: [ -e boot.conf ] && sed -E '/^ *(set +image|boot) +/!d ; \
130: s///; s/^.*://; s/ .*$//' boot.conf \
131: ) | tail -1 )
132: _k=$( follow_symlink $_k )
133:
134: local _d=$( dirname $_k )
135: [ "$_d" = "." ] && _d=$PWD
136:
137: if [ $_d = . -o $_d = $PWD ]; then
138: basename $_k
139: else
140: echo $_k
141: fi
142: }
143:
1.2 andrew 144: set_version() {
145: CUR_VER=`uname -r`
1.3 andrew 146: NEW_VER=`dc -e "$CUR_VER 0.1 + p"`
1.5 andrew 147: FILE_VER=""
148: FTP=""
1.2 andrew 149:
1.5 andrew 150: local _cv=`echo $CUR_VER | sed -e 's/\.//'`
151: local _nv=`echo $NEW_VER | sed -e 's/\.//'`
1.9 andrew 152: local _v
1.5 andrew 153:
1.10 andrew 154: if [ X"No" != X"$FORCE_DIR" -a -d $FORCE_DIR ]; then
1.5 andrew 155: _dir=$FORCE_DIR
156: if [ -e ${_dir}/base${_nv}.tgz ]; then
157: _v=$_nv
158: elif [ -e ${_dir}/base${_cv}.tgz ]; then
159: NEW_VER=$CUR_VER
160: _v=$_cv
161: fi
1.2 andrew 162:
1.5 andrew 163: elif [ -d $CUR_VER ]; then
164: _dir=$CUR_VER
1.2 andrew 165: NEW_VER=$CUR_VER
1.5 andrew 166: if [ -e ${_dir}/base${_cv}.tgz ]; then
167: _v=$_cv
168: fi
1.2 andrew 169:
1.5 andrew 170: elif [ -d $NEW_VER ]; then
171: _dir=$NEW_VER
172: if [ -e ${_dir}/base${_nv}.tgz ]; then
173: _v=$_nv
174: fi
1.2 andrew 175:
176: fi
177:
1.17 andrew 178: if [ X"" != X"${MIRROR}" -a X"" == X"${_v}" ]; then
1.89 andrew 179: if [ X"No" != X"${FORCE_DIR}" ]; then
180: _dir=${FORCE_DIR}
181: elif sysctl kern.version | grep -q -- '-current '; then
182: _dir=snapshots
183: FORCE_DIR=snapshots
184: else
1.5 andrew 185: _dir=${NEW_VER}
186: fi
187: FTP=${MIRROR}/${_dir}/`machine`
1.2 andrew 188:
1.16 andrew 189: _v=`version_in`
1.10 andrew 190:
1.16 andrew 191: if [ X"" == X"${_v}" ]; then
1.10 andrew 192: if [ X"No" != X"$FORCE_DIR" ]; then
193: echo No sets in forced [${FTP}] >&2
1.12 andrew 194: return 2
1.10 andrew 195: fi
196:
197: NEW_VER=$CUR_VER
198: _dir=${NEW_VER}
199: FTP=${MIRROR}/${_dir}/`machine`
200:
1.16 andrew 201: _v=`version_in`
1.9 andrew 202: fi
203:
1.10 andrew 204: if [ X"" == X"${_v}" ]; then
1.16 andrew 205: echo No sets in [${FTP}] >&2
1.94 andrew 206: return 2
1.10 andrew 207: elif [ X"${_cv}" == X"${_v}" ]; then
1.5 andrew 208: NEW_VER=$CUR_VER
1.9 andrew 209: elif [ X"${_nv}" == X"${_v}" ]; then
210: NEW_VER=$NEW_VER
1.2 andrew 211: else
1.10 andrew 212: echo Invalid version [$_v] >&2
1.12 andrew 213: return 2
1.2 andrew 214: fi
215:
1.10 andrew 216: if [ X"No" == X"$FORCE_DIR" ]; then
1.5 andrew 217: _dir=$NEW_VER
1.2 andrew 218: fi
219:
220: fi
221:
1.5 andrew 222: if [ X"" == X"${_v}" ]; then
1.64 andrew 223: if [ X"" == X"${MIRROR}" ]; then
224: echo ERROR: No sets, and no MIRROR, unable to continue. >&2
225: else
226: echo ERROR: Unable to determine FILE_VER, check your MIRROR. >&2
227: fi
1.12 andrew 228: return 1
1.2 andrew 229: fi
230:
1.5 andrew 231: if [ X"" == X"$RELEASEDIR" ]; then
232: RELEASEDIR=`pwd`/$_dir
1.2 andrew 233: fi
1.9 andrew 234:
1.5 andrew 235: FILE_VER=$_v
1.17 andrew 236: if [ X"" != X"${MIRROR}" ]; then
237: FTP=${MIRROR}/${_dir}/`machine`
238: fi
1.39 andrew 239:
1.101 andrew 240: KERNEL_ROOT=""
241: [ -z "$BOOT_DEVICE" ] && set_boot_device
242:
1.104 andrew 243: mount_boot_device
244: cd $KERNEL_ROOT
245: BOOT_KERNEL=$( find_boot_kernel )
246: BOOT_KERNEL_VERSION=$( kernel_file_version $BOOT_KERNEL )
1.106 andrew 247: if [ $(sysctl -n hw.ncpufound) -gt 1 ] || kernel_is_multiprocessor $BOOT_KERNEL; then
248: BOOT_KERNEL=bsd.mp
249: fi
1.39 andrew 250:
251: BOOTED_KERNEL_VERSION=`sysctl -n kern.version`
252: NEW_KERNEL_VERSION=""
253:
254: # We want to default to what we had
1.104 andrew 255: INSTALL_KERNELS="$BOOT_KERNEL"
1.48 andrew 256: # if the boot kernel was our specially named bsd.sp, we install from bsd
257: if [ X"$INSTALL_KERNELS" == X"bsd.sp" ]; then
258: INSTALL_KERNELS="bsd"
259: fi
1.106 andrew 260:
261: # We want to update all kernels that exist
262: # either in the $KERNEL_ROOT or in /
263: for b in bsd bsd.mp; do
264: [ -e $b -o -e /$b ] || continue
265: if [ X"${INSTALL_KERNELS% *}" != X"$b" ]; then
266: INSTALL_KERNELS="$INSTALL_KERNELS $b"
267: fi
268: done
269:
270: cd $OLDPWD
271: umount_boot_device
272:
1.39 andrew 273: BOOT_KERNELS=$INSTALL_KERNELS
274: INSTALL_KERNELS="$INSTALL_KERNELS bsd.rd"
1.2 andrew 275: }
276:
277: get_sets() {
1.54 andrew 278: echo '==> GETTING SETS'
1.2 andrew 279: if [ X"" == X"$FTP" ]; then
1.5 andrew 280: echo ERROR: No FTP site set! >&2
1.12 andrew 281: return 1
1.2 andrew 282: fi
283:
1.5 andrew 284: mkdir -p ${RELEASEDIR}
285: cd $RELEASEDIR
1.2 andrew 286:
1.5 andrew 287: local _v=$FILE_VER
1.2 andrew 288:
1.39 andrew 289: for _b in $INSTALL_KERNELS; do
1.45 andrew 290: if [ ! -e ./${_b} ]; then
1.54 andrew 291: echo "===> $FTP_CMD ${FTP}/${_b}"
1.3 andrew 292: $FTP_CMD ${FTP}/${_b}
1.70 andrew 293: else
294: echo "===> Have ${_b}"
1.2 andrew 295: fi
1.70 andrew 296: kernel_file_version "${_b}"
1.2 andrew 297: done
298:
1.5 andrew 299: for _s in $INSTALLED_SETS; do
1.71 andrew 300: [ "$_v" -ge "57" -a "$_s" != "${_s%etc}" ] && continue
1.19 andrew 301: local _file=${_s}${_v}.tgz
302: if [ ${_s} == sendmail-smtp_auth ]; then
303: _file=${_s}.gz
304: fi
305:
306: if [ ! -e ./${_file} ]; then
1.54 andrew 307: echo "===> $FTP_CMD ${FTP}/${_file}"
1.19 andrew 308: $FTP_CMD ${FTP}/${_file}
1.5 andrew 309: fi
1.2 andrew 310: done
311:
1.20 andrew 312: local _type
1.56 andrew 313: local _ftp
1.20 andrew 314: for _type in $CHECKSUM_TYPES; do
1.40 andrew 315: [ -e $_type ] && break
1.56 andrew 316: _ftp=`echo "$FTP" | sed -e 's,://[^/]*/,://ftp.openbsd.org/,'`
317: echo "===> $FTP_CMD ${_ftp}/$_type"
318: $FTP_CMD ${_ftp}/$_type
1.20 andrew 319: done
1.17 andrew 320: }
321:
1.23 andrew 322: follow_symlink () {
323: local _file=$1
1.33 andrew 324: # This could go circular, but I dunno how to fix that.
325: if [ -h $_file ]; then
1.77 andrew 326: follow_symlink $( readlink -f $_file )
1.23 andrew 327: else
1.33 andrew 328: echo $_file
1.23 andrew 329: fi
330: }
331:
1.20 andrew 332: check_sum () {
333: local _type=$1
1.54 andrew 334: echo "==> CHECKING $_type SUMS"
1.17 andrew 335: cd $RELEASEDIR
336:
1.20 andrew 337: if [ ! -e $_type ]; then
338: echo $_type File does not exist!
1.17 andrew 339: return 1
340: fi
1.6 andrew 341:
1.57 andrew 342: local _nv=`echo $NEW_VER | sed -e 's/\.//'`
1.61 andrew 343: local _signify=`which signify 2>/dev/null`
1.94 andrew 344: local _keyfile=/etc/signify/openbsd-${_nv}-base.pub
1.59 andrew 345: local _b _s
1.57 andrew 346:
347: (
1.58 andrew 348: for _b in $INSTALL_KERNELS; do echo "($_b)" ; done
349: for _s in $INSTALLED_SETS; do echo "($_s$_nv.tgz)"; done
1.57 andrew 350: ) > index
1.94 andrew 351:
1.59 andrew 352:
353: if [ -n "$_signify" -a "$_type" != "${_type%.sig}" ]; then
354: echo "===> Checking signature";
355: if [ ! -e $_keyfile ]; then
356: echo "key [$_keyfile] does not exist, cannot check $_type" >&2
357: return 2
358: fi
1.67 andrew 359: signify -V -e -p $_keyfile -x $_type -m - | grep -f index | sha256 -c -
1.59 andrew 360: else
1.73 andrew 361: grep -f index $_type | sha256 -c
1.59 andrew 362: fi
1.2 andrew 363:
364: if [ $? -ne 0 ]; then
1.20 andrew 365: echo ERROR: $_type does not match! >&2
1.12 andrew 366: return 1
1.2 andrew 367: fi
368: }
369:
1.17 andrew 370: check_sets() {
1.54 andrew 371: echo '==> CHECKING SETS'
1.17 andrew 372: cd $RELEASEDIR
373:
1.18 andrew 374: local _missing_sets
1.17 andrew 375: local _v=$FILE_VER
376:
1.104 andrew 377: mount_boot_device
1.39 andrew 378: for _n in $INSTALL_KERNELS; do
379: local _o=$_n
1.104 andrew 380: [ X"bsd" == X"${_o}" -a -e ${KERNEL_ROOT}bsd.sp ] && _o=bsd.sp
381: if [ -e ${KERNEL_ROOT}${_o} -a ! -e ./${_n} ]; then
382: echo ${_o} does not exist on $BOOT_DEVICE
1.39 andrew 383: _missing_sets=1
1.17 andrew 384: fi
1.39 andrew 385:
1.104 andrew 386: if [ X"${BOOT_KERNEL}" == X"${_o}" -a -e ./${_n} ]; then
1.39 andrew 387: NEW_KERNEL_VERSION=`kernel_file_version ./${_n}`
1.17 andrew 388: fi
389: done
1.104 andrew 390: umount_boot_device
1.17 andrew 391:
1.39 andrew 392: if [ X"$NEW_KERNEL_VERSION" == X"" ]; then
393: echo Missing replacement for boot kernel $BOOT_KERNEL >&2
394: _missing_sets=1
395: fi
396:
1.17 andrew 397: for _s in $INSTALLED_SETS; do
1.71 andrew 398: [ "$_v" -ge "57" -a "$_s" != "${_s%etc}" ] && continue
1.19 andrew 399: local _file=${_s}${_v}.tgz
400: if [ ${_s} == sendmail-smtp_auth ]; then
401: _file=${_s}.gz
402: fi
403: if [ ! -e ./${_file} ]; then
404: echo ${_file} does not exist
1.18 andrew 405: _missing_sets=1
1.17 andrew 406: fi
407: done
1.18 andrew 408:
409: if [ X"" == X"${_missing_sets}" ]; then
1.85 andrew 410: echo 'All OK'
1.18 andrew 411: fi
1.17 andrew 412:
1.20 andrew 413: local _type
414: for _type in $CHECKSUM_TYPES; do
1.74 andrew 415: [ -n "$NO_SIGNIFY" -a "$_type" != "${_type%.sig}" ] && continue
1.20 andrew 416: if [ -e $_type ]; then
1.59 andrew 417: check_sum $_type && break
1.62 andrew 418: [ -z "$IGNORE_CHECKSUM_ERROR" ] && exit 1
1.20 andrew 419: fi
420: done
1.59 andrew 421:
422: return 0
1.17 andrew 423: }
424:
425:
1.30 andrew 426: install_kernels() {
1.110 ! andrew 427: local _d="$1"
1.99 andrew 428: local default_mount
1.97 andrew 429: local boot_mount
430: local mount_is_msdos
431:
1.110 ! andrew 432: if [ "$_d" ]; then
! 433: _d=$( readlink -nf "$_d" )
! 434: else
1.99 andrew 435: default_mount=$( df -lnP /bsd | sed -ne 's!/dev/.* !!p' )
1.101 andrew 436: mount_boot_device
1.97 andrew 437:
1.101 andrew 438: if [ "$KERNEL_ROOT" != "$default_mount" ]; then
1.99 andrew 439: local _ik="$INSTALL_KERNELS"
1.104 andrew 440: INSTALL_KERNELS="$BOOT_KERNEL bsd.rd"
1.97 andrew 441:
1.101 andrew 442: install_kernels $KERNEL_ROOT
1.99 andrew 443:
444: INSTALL_KERNELS="$_ik"
1.97 andrew 445: fi
446:
1.99 andrew 447: umount_boot_device
448:
1.97 andrew 449: install_kernels $default_mount
450: return
451: fi
452:
453: echo "==> INSTALLING KERNEL to $_d"
1.2 andrew 454:
455: if [ X"" == X"$RELEASEDIR" ]; then
1.5 andrew 456: echo ERROR: no source for new kernels! >&2
1.2 andrew 457: exit 1
458: fi
459:
1.100 andrew 460: [ $_d != / ] && mount | grep -q " on ${_d%/} .* msdos" && mount_is_msdos=1
1.110 ! andrew 461: [ $_d != / ] && $_d=$_d/
1.97 andrew 462:
1.46 andrew 463: if [ X"$BOOT_KERNEL_VERSION" != X"$NEW_KERNEL_VERSION" ]; then
1.97 andrew 464: echo "===> Backing up $BOOT_KERNEL to ${_d}obsd"
465: if [ $mount_is_msdos ]; then
1.107 andrew 466: cp ${_d}$BOOT_KERNEL ${_d}obsd
1.97 andrew 467: else
1.107 andrew 468: ln -f ${_d}$BOOT_KERNEL ${_d}obsd
1.97 andrew 469: fi
1.46 andrew 470: if [ $? -ne 0 ]; then
471: echo "Error copying old kernel!" >&2
472: exit 1
473: fi
1.2 andrew 474: fi
475:
1.39 andrew 476: cd $RELEASEDIR
1.23 andrew 477:
1.39 andrew 478: for _b in $INSTALL_KERNELS; do
1.97 andrew 479: rm -f ${_d}nbsd
1.39 andrew 480: local _bd=$_b
481: [ X"${_b}" == X"bsd" ] && _bd="bsd.sp"
1.2 andrew 482:
1.39 andrew 483: local _is_boot=""
1.97 andrew 484: [ X"$BOOT_KERNEL" == X"${_d}${_bd}" ] && _is_boot="# boot kernel"
1.94 andrew 485:
1.97 andrew 486: echo "Copying $_b to ${_d}$_bd $_is_boot"
487: cp ${_b} ${_d}nbsd && mv ${_d}nbsd ${_d}${_bd}
1.2 andrew 488: if [ $? -ne 0 ]; then
1.39 andrew 489: echo ERROR: Could not copy new $_bd kernel! >&2
1.2 andrew 490: exit 1
491: fi
1.39 andrew 492: done
493:
494: cd $OLDPWD
1.23 andrew 495:
1.97 andrew 496: if [ ! -h ${_d}bsd ]; then
497: cd ${_d}
1.39 andrew 498: for _b in $BOOT_KERNELS; do
499: [ X"$_b" == X"bsd" ] && _b="bsd.sp"
500: if [ -e $_b ]; then
1.97 andrew 501: if [ "$mount_is_msdos" ]; then
502: echo "===> Moving $_b ${_d}bsd (MSDOS)"
503: mv -f ${_b} bsd
504: else
505: echo "===> symlinking $_b to ${_d}bsd"
506: ln -sf $_b bsd
1.39 andrew 507: fi
508: break
509: fi
510: done
1.97 andrew 511: cd $OLDPWD
1.2 andrew 512: fi
513: }
514:
515: install_sets() {
1.54 andrew 516: echo '==> INSTALLING SETS'
1.2 andrew 517:
518: if [ X"" == X"$RELEASEDIR" ]; then
1.5 andrew 519: echo ERROR: no source for sets! >&2
1.2 andrew 520: exit 1
521: else
522: cd $RELEASEDIR
523: fi
524:
1.5 andrew 525: local _v=$FILE_VER
526:
1.21 andrew 527: local _sets=`ls *${_v}.tgz | grep -v ^base `
528: for _f in ${_sets} base${_v}.tgz; do
1.3 andrew 529: _path=$DESTDIR
530: if [ X"etc${_v}.tgz" == X"$_f" \
531: -o X"xetc${_v}.tgz" == X"$_f" ]; then
1.21 andrew 532: [ X"" != X"$SYSMERGE" ] && continue
1.2 andrew 533: _path=/var/tmp/temproot
534: fi
535:
1.85 andrew 536: echo "Extracting $_f to $_path"
1.65 andrew 537: mkdir -p $_path
538: tar -C $_path -xzphf ${RELEASEDIR}/${_f}
1.2 andrew 539: if [ $? -ne 0 ]; then
1.5 andrew 540: echo ERROR: Could not extract ${_f}! >&2
1.2 andrew 541: exit 1
542: fi
543: done
544:
1.54 andrew 545: echo '===> Extracted all sets.'
1.51 andrew 546: }
1.19 andrew 547:
1.51 andrew 548: install_sendmail_smtp_auth() {
1.19 andrew 549: if [ -e ${RELEASEDIR}/sendmail-smtp_auth.gz ]; then
550: gzcat ${RELEASEDIR}/sendmail-smtp_auth.gz > \
551: ${RELEASEDIR}/sendmail-smtp_auth
552: fi
553: if [ -e ${RELEASEDIR}/sendmail-smtp_auth ]; then
1.21 andrew 554: if ! pkg_info -qe 'cyrus-sasl-*'; then
1.65 andrew 555: pkg_add -i cyrus-sasl
1.21 andrew 556: fi
557:
1.65 andrew 558: install -o root -g smmsp -m 2555 \
1.19 andrew 559: ${RELEASEDIR}/sendmail-smtp_auth \
1.21 andrew 560: /usr/libexec/sendmail/sendmail
1.19 andrew 561:
1.54 andrew 562: echo '===> Installed sendmail with smtp_auth'
1.19 andrew 563: fi
1.2 andrew 564: }
565:
566: update_etc() {
1.54 andrew 567: echo '==> UPDATING ETC'
1.10 andrew 568: if [ ! -e $SYSMERGE ]; then
1.47 andrew 569: echo "ERROR: Can't find sysmerge!" >&2
570: exit 1;
1.10 andrew 571: fi
572:
1.68 andrew 573: local _v=$FILE_VER
574: local _args=""
575:
1.80 andrew 576: if [ ! -e /var/sysmerge/etc.tgz ]; then
1.68 andrew 577: if [ X"" == X"$RELEASEDIR" ]; then
578: echo "ERROR: no source for etc!" >&2
579: exit 1
580: fi
1.2 andrew 581:
1.68 andrew 582: cd $RELEASEDIR
1.5 andrew 583:
1.68 andrew 584: if [ -e etc${_v}.tgz ]; then
585: _args="$_args -s ${RELEASEDIR}/etc${_v}.tgz"
586: fi
587: if [ -e xetc${_v}.tgz ]; then
588: _args="$_args -x ${RELEASEDIR}/xetc${_v}.tgz"
589: fi
1.94 andrew 590: if [ X"" == X"$_args" ]; then
1.68 andrew 591: echo ERROR: No upgrade sets found! >&2
592: exit 1
593: fi
1.47 andrew 594: fi
1.68 andrew 595:
596: echo '==> RUNNING SYSMERGE'
597: $SYSMERGE $_args
1.2 andrew 598:
1.47 andrew 599: cd $OLDPWD
1.2 andrew 600: }
1.14 andrew 601:
1.20 andrew 602:
1.65 andrew 603: if [ $(id -u) != 0 ]; then
604: echo 'ERROR: need root privileges to run this script' >&2
605: exit 1
606: fi
607:
1.14 andrew 608: if [ -e /etc/update_openbsd.conf ]; then
609: . /etc/update_openbsd.conf
610: fi
611:
612: if [ -e ${HOME}/.update_openbsdrc ]; then
613: . ${HOME}/.update_openbsdrc
614: fi
615:
1.108 andrew 616: MIRROR=${MIRROR:=http://cdn.openbsd.org/pub/OpenBSD}
1.14 andrew 617: FTP_CMD=${FTP_CMD:=ftp -V}
618:
619: DESTDIR=${DESTDIR:=/}
620: SYSMERGE=${SYSMERGE:=/usr/sbin/sysmerge}
621: FORCE_DIR=${FORCE_DIR:=No}
1.79 andrew 622:
1.84 andrew 623: export PKG_PATH TRUSTED_PKG_PATH
624:
1.79 andrew 625: set_version
1.91 andrew 626:
1.95 andrew 627: TRUSTED_PKG_PATH=${TRUSTED_PKG_PATH:=/usr/ports/packages/`machine -a`/all}
628: if [ "$FORCE_DIR" = "No" ]; then
629: PKG_PATH=${PKG_PATH:=${MIRROR}/$NEW_VER/packages/`machine -a`}
630: else
631: PKG_PATH=${PKG_PATH:=${MIRROR}/$FORCE_DIR/packages/`machine -a`}
632: fi
1.14 andrew 633:
634: INSTALLED_SETS=${INSTALLED_SETS:=`installed_sets`}
1.2 andrew 635:
1.59 andrew 636: CHECKSUM_TYPES=${CHECKSUM_TYPES:=SHA256.sig SHA256}
1.20 andrew 637:
1.12 andrew 638: local _error=$?
1.2 andrew 639:
640: echo
641: echo "-= update_openbsd - helper script to update OpenBSD =-"
642: echo "------------------------------------------------------"
643: echo
1.84 andrew 644: echo " SYSMERGE: $SYSMERGE"
1.88 andrew 645: echo " MIRROR: $FTP"
1.84 andrew 646: echo " PKG_PATH: $PKG_PATH"
647: echo "TRUSTED_PKG_PATH: $TRUSTED_PKG_PATH"
648: echo " RELEASEDIR: $RELEASEDIR"
649: echo " DESTDIR: $DESTDIR"
1.98 andrew 650: echo " BOOT_DEVICE: $BOOT_DEVICE"
1.84 andrew 651: echo " BOOT_KERNEL: $BOOT_KERNEL"
652: echo " INSTALL_KERNELS: $INSTALL_KERNELS"
653: echo " INSTALLED_SETS: $INSTALLED_SETS"
1.8 andrew 654: echo
1.84 andrew 655: echo " CUR_VER: $CUR_VER"
656: echo " NEW_VER: $NEW_VER"
657: #echo " FILE_VER: $FILE_VER"
1.2 andrew 658: echo
1.70 andrew 659:
1.104 andrew 660: mount_boot_device
1.70 andrew 661: for k in $INSTALL_KERNELS; do
1.104 andrew 662: if [ -e $KERNEL_ROOT$k ]; then
663: echo "Existing $BOOT_DEVICE:$k"
664: kernel_file_version $KERNEL_ROOT$k
1.70 andrew 665: fi
666: done
1.104 andrew 667: umount_boot_device
1.12 andrew 668:
669: if [ ${_error} -ne 0 ]; then
670: exit ${_error}
671: fi
1.2 andrew 672:
1.17 andrew 673: if [ X"" != X"${FTP}" ]; then
1.20 andrew 674: get_sets
1.17 andrew 675: fi
676:
677: check_sets || exit
1.39 andrew 678:
1.54 andrew 679: echo "===> Last booted:\n$BOOTED_KERNEL_VERSION"
1.39 andrew 680: if [ X"$BOOT_KERNEL_VERSION" != X"$BOOTED_KERNEL_VERSION" \
681: -a X"$BOOT_KERNEL_VERSION" != X"$NEW_KERNEL_VERSION" ]; then
682: echo "Next boot (unless replaced):\n$BOOT_KERNEL_VERSION"
683: fi
684: if [ -n "$NEW_KERNEL_VERSION" ]; then
1.54 andrew 685: echo "===> New $BOOT_KERNEL:\n$NEW_KERNEL_VERSION";
1.39 andrew 686: else
687: echo "\n!!! WARNING: Will not replace boot kernel $BOOT_KERNEL! !!!\n" >&2
688: echo "ctrl+C to cancel, enter to continue anyway" >&2
1.44 andrew 689: local _temp
690: read _temp
1.53 andrew 691: NEW_KERNEL_VERSION=$BOOT_KERNEL_VERSION
1.44 andrew 692: fi
693:
1.66 andrew 694: if [ X"$NEW_KERNEL_VERSION" != X"$BOOTED_KERNEL_VERSION" ]; then
1.44 andrew 695: echo >&2
1.66 andrew 696: echo "!!! You are upgrading the OpenBSD kernel. !!!" >&2
697: echo "!!! You will be given the opportunity to reboot !!!" >&2
1.94 andrew 698: echo "!!! at the end of the proces but it is safer to !!!" >&2
1.66 andrew 699: echo "!!! have a separate root shell open. !!!" >&2
700: echo "!!! It is needed in order to run /sbin/oreboot. !!!" >&2
1.78 andrew 701: echo "!!! doas MAY NOT WORK after sets are extracted. !!!" >&2
1.44 andrew 702: echo >&2
1.66 andrew 703: echo "enter to continue, ctrl+C to cancel" >&2
1.39 andrew 704: local _temp
705: read _temp
1.2 andrew 706:
1.66 andrew 707: if [ ! -e /sbin/oreboot ]; then
708: cp /sbin/reboot /sbin/oreboot
709: if [ $? -ne 0 ]; then
710: echo "Error copying old reboot command!" >&2
711: exit 1
712: fi
713: echo "/sbin/reboot copied to /sbin/oreboot"
1.50 andrew 714: fi
1.2 andrew 715: fi
716:
1.30 andrew 717: install_kernels
1.21 andrew 718: install_sets
1.2 andrew 719:
1.53 andrew 720: if [ X"$NEW_KERNEL_VERSION" == X"$BOOTED_KERNEL_VERSION" ]; then
1.51 andrew 721: install_sendmail_smtp_auth
722:
1.21 andrew 723: if [ -e /sbin/oreboot ]; then
724: echo Removing /sbin/oreboot
1.69 andrew 725: rm -f /sbin/oreboot
1.21 andrew 726: fi
1.2 andrew 727: update_etc
728:
1.81 andrew 729: OPENUP=$( which openup 2>/dev/null )
1.76 andrew 730: if [ -n "$OPENUP" ]; then
731: echo "==> UPDATING WITH $OPENUP"
732: $OPENUP
733: else
734: echo '==> UPDATING PACKAGES'
1.86 andrew 735: pkg_add -u
1.76 andrew 736: fi
1.72 andrew 737:
738: echo '==> UPDATING FIRMWARE'
739: fw_update
1.2 andrew 740:
741: else
1.83 andrew 742: [ -e /etc/rc.sysmerge ] && grep -q $SYSMERGE /etc/rc.sysmerge ||
1.82 andrew 743: echo "$SYSMERGE -b" >>/etc/rc.sysmerge &&
744: echo "==> RUNNING $SYSMERGE -b ON REBOOT"
745:
1.94 andrew 746: echo Instructions for updating to the new version available from
1.36 andrew 747: if [ X"snapshots" == X"$FORCE_DIR" ]; then
1.30 andrew 748: echo " http://www.openbsd.org/faq/current.html"
749: else
750: echo " http://www.openbsd.org/faq/upgrade${FILE_VER}.html"
751: fi
1.2 andrew 752: fi
753:
1.66 andrew 754: echo Update complete. enter to reboot, ctrl+C to cancel
1.65 andrew 755: read _temp
1.22 andrew 756: if [ -e /sbin/oreboot ]; then
1.66 andrew 757: echo using /sbin/oreboot
1.65 andrew 758: /sbin/oreboot
759: else
760: /sbin/reboot
1.22 andrew 761: fi
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>