Commit d4b0b2af authored by Franco Fichtner's avatar Franco Fichtner

rc: rebuild the command line backup restore

This is a shell script to make recovery as recoverable as
possible, now with a clear license and the ability to apply
inline or reboot for a clean configuration cycle.
parent 9d392294
...@@ -96,6 +96,7 @@ ...@@ -96,6 +96,7 @@
/usr/local/etc/rc.initial.password /usr/local/etc/rc.initial.password
/usr/local/etc/rc.initial.ping /usr/local/etc/rc.initial.ping
/usr/local/etc/rc.initial.reboot /usr/local/etc/rc.initial.reboot
/usr/local/etc/rc.initial.restore
/usr/local/etc/rc.initial.setlanip /usr/local/etc/rc.initial.setlanip
/usr/local/etc/rc.initial.setports /usr/local/etc/rc.initial.setports
/usr/local/etc/rc.installer /usr/local/etc/rc.installer
......
...@@ -15,11 +15,6 @@ if [ -n "${*}" ]; then ...@@ -15,11 +15,6 @@ if [ -n "${*}" ]; then
exit ${?} exit ${?}
fi fi
OPT_RESTORE="13) Restore configuration"
if [ ! -f /usr/local/etc/rc.initial.restore ]; then
OPT_RESTORE=
fi
# endless loop # endless loop
while : ; do while : ; do
...@@ -37,7 +32,7 @@ echo " 2) Set interface IP address 9) pfTop" ...@@ -37,7 +32,7 @@ echo " 2) Set interface IP address 9) pfTop"
echo " 3) Reset the root password 10) Firewall log" echo " 3) Reset the root password 10) Firewall log"
echo " 4) Reset to factory defaults 11) Reload all services" echo " 4) Reset to factory defaults 11) Reload all services"
echo " 5) Power off system 12) Upgrade from console" echo " 5) Power off system 12) Upgrade from console"
echo " 6) Reboot system ${OPT_RESTORE}" echo " 6) Reboot system 13) Restore a backup"
echo echo
read -p "Enter an option: " OPCODE read -p "Enter an option: " OPCODE
echo echo
...@@ -87,9 +82,7 @@ case ${OPCODE} in ...@@ -87,9 +82,7 @@ case ${OPCODE} in
/usr/local/etc/rc.initial.firmware /usr/local/etc/rc.initial.firmware
;; ;;
13) 13)
if [ -n "${OPT_RESTORE}" ]; then /usr/local/etc/rc.initial.restore
/usr/local/etc/rc.initial.restore
fi
;; ;;
*) *)
;; ;;
......
#!/bin/sh
# Copyright (c) 2017 Franco Fichtner <franco@opnsense.org>
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
#
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.
set -e
if [ ! -d /conf/backup ]; then
echo "No backups available."
exit 0
fi
BACKUPS="$(cd /conf/backup; find . -name "config-*.xml")"
if [ -z "${BACKUPS}" ]; then
echo "No backups available."
exit 0
fi
DATED=
for BACKUP in ${BACKUPS}; do
DATETIME=${BACKUP#*config-}
DATETIME=${DATETIME%.xml}
SUBSEC=${DATETIME#*.}
DATETIME=${DATETIME%.*}
# write a line with all required info that is prefixed
# with a sortable time stamp for our next step...
DATED="${DATED}$(date -r ${DATETIME} '+%Y-%m-%dT%H:%M:%S').${SUBSEC} ${DATETIME} ${BACKUP}
"
done
SORTED="$(echo -n "${DATED}" | sort -r | head -n 18)"
INDEX=0
RESTORE=
while [ -z "${RESTORE}" ]; do
echo "${SORTED}" | while read SORT DATETIME BACKUP; do
INDEX=$((INDEX+1))
# carefully crafted whitespace pattern with
# embedded alignment tab, edit carefully
echo " ${INDEX}. $(date -r ${DATETIME})"
done
echo
read -p "Select backup to restore or leave blank to exit: " SELECT
if [ -z "${SELECT}" ]; then
exit 0
fi
RESTORE="$(echo "${SORTED}" | while read SORT DATETIME BACKUP; do
INDEX=$((INDEX+1))
if [ "${INDEX}" = "${SELECT}" ]; then
echo "${BACKUP}"
break
fi
done)"
echo
done
cp /conf/backup/${RESTORE} /conf/config.xml
read -p "Do you want to reboot to apply the backup cleanly? [y/N]: " YN
case ${YN} in
[yY])
/usr/local/etc/rc.reboot
;;
*)
/usr/local/etc/rc.reload_all
;;
esac
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment