X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/4e9554bdfe13fa5ce42098c4b04531d501654e5c..c31e54429a547a36431f6f9c01fd1f16952b37d9:/package/base-files/files/sbin/sysupgrade diff --git a/package/base-files/files/sbin/sysupgrade b/package/base-files/files/sbin/sysupgrade index 432539a2f..1825cec58 100755 --- a/package/base-files/files/sbin/sysupgrade +++ b/package/base-files/files/sbin/sysupgrade @@ -8,6 +8,7 @@ export INTERACTIVE=0 export VERBOSE=1 export SAVE_CONFIG=1 export DELAY= +export CONF_IMAGE= # parse options while [ -n "$1" ]; do @@ -16,6 +17,8 @@ while [ -n "$1" ]; do -d) export DELAY="$2"; shift;; -v) export VERBOSE="$(($VERBOSE + 1))";; -q) export VERBOSE="$(($VERBOSE - 1))";; + -n) export SAVE_CONFIG=0;; + -f) export CONF_IMAGE="$2"; shift;; -*) echo "Invalid option: $1" exit 1 @@ -37,7 +40,9 @@ Usage: $0 [options] Options: -d add a delay before rebooting + -f restore configuration from .tar.gz (file or url) -i interactive mode + -n do not save configuration over reflash -q less verbose -v more verbose @@ -83,7 +88,18 @@ for check in $sysupgrade_image_check; do } done -if ask_bool $SAVE_CONFIG "Keep config files over reflash"; then +if [ -n "$CONF_IMAGE" ]; then + case "$(get_magic_word "$CONF_IMAGE")" in + # .gz files + 1f8b) ;; + *) + echo "Invalid config file. Please use only .tar.gz files" + exit 1 + ;; + esac + get_image "$CONF_IMAGE" > "$CONF_TAR" + export SAVE_CONFIG=1 +elif ask_bool $SAVE_CONFIG "Keep config files over reflash"; then do_save_conffiles export SAVE_CONFIG=1 else