V6.1.0 优化代码
This commit is contained in:
		
							parent
							
								
									11781f419f
								
							
						
					
					
						commit
						ca96bb6059
					
				|  | @ -8,16 +8,7 @@ TITLE() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| SHELL_HELP() { | SHELL_HELP() { | ||||||
| 	case $1 in |  | ||||||
| 	1) |  | ||||||
| 	TITLE | 	TITLE | ||||||
| 		shift |  | ||||||
| 		TIME r "错误的输入: [$0 $*]" |  | ||||||
| 	;; |  | ||||||
| 	*) |  | ||||||
| 		TITLE |  | ||||||
| 	;; |  | ||||||
| 	esac |  | ||||||
| 	cat <<EOF | 	cat <<EOF | ||||||
| 
 | 
 | ||||||
| 使用方法:	$0 [<path=>] [-P] [-n] [-f] [-u] | 使用方法:	$0 [<path=>] [-P] [-n] [-f] [-u] | ||||||
|  | @ -39,22 +30,22 @@ SHELL_HELP() { | ||||||
| 	-T,--test		测试模式 (可附加) | 	-T,--test		测试模式 (可附加) | ||||||
| 	-P,--proxy		强制使用 [FastGit] 加速 (可附加) | 	-P,--proxy		强制使用 [FastGit] 加速 (可附加) | ||||||
| 	-C <Github URL>		更改 Github 地址 | 	-C <Github URL>		更改 Github 地址 | ||||||
| 	-B <UEFI/Legacy>	指定 x86_64 设备下载 UEFI 或 Legacy 引导的固件 (危险) | 	-B <UEFI | Legacy>	指定 x86_64 设备下载 <UEFI | Legacy> 引导的固件 (危险) | ||||||
| 	-H,--help		打印 AutoUpdate 帮助信息 | 	--help			打印 AutoUpdate 帮助信息 | ||||||
| 	-L,--list		打印当前系统信息 | 	-L,--list		打印当前系统信息 | ||||||
| 	-U			检查版本更新 | 	-U			检查版本更新 | ||||||
| 	--corn <task=> <time>	设置定时任务 | 	--corn <task=> <time>	设置定时任务 | ||||||
| 	--corn-del		删除所有 AutoUpdate 定时任务 | 	--corn-rm		删除所有 AutoUpdate 定时任务 | ||||||
| 	--bak <path> <name>	备份 Openwrt 配置文件到用户指定的目录 | 	--bak <path> <name>	备份 Openwrt 配置文件到用户指定的目录 | ||||||
| 	--clean			清理固件下载缓存 | 	--clean			清理固件下载缓存 | ||||||
| 	--check			检查 AutoUpdate 依赖软件包 | 	--check			检查 AutoUpdate 依赖软件包 | ||||||
| 	--var <variable>	打印用户指定的 <variable> | 	--var <variable>	打印用户指定的 <variable> | ||||||
| 	--var-del <variable>	删除用户指定的 <variable> | 	--var-rm <variable>	删除用户指定的 <variable> | ||||||
| 	--log			打印 AutoUpdate 历史运行日志 | 	--log			打印 AutoUpdate 历史运行日志 | ||||||
| 	--log-path <path>	更改 AutoUpdate 运行日志保存目录 | 	--log-path <path>	更改 AutoUpdate 运行日志保存目录 | ||||||
| 
 | 
 | ||||||
| EOF | EOF | ||||||
| 	exit 0 | 	EXIT 1 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| SHOW_VARIABLE() { | SHOW_VARIABLE() { | ||||||
|  | @ -69,8 +60,8 @@ SHOW_VARIABLE() { | ||||||
| 作者仓库:		${Github} | 作者仓库:		${Github} | ||||||
| 源码仓库:		https://github.com/${Openwrt_Author}/${Openwrt_Repo_Name}:${Openwrt_Branch}	 | 源码仓库:		https://github.com/${Openwrt_Author}/${Openwrt_Repo_Name}:${Openwrt_Branch}	 | ||||||
| Release API:		${Github_Tag_URL} | Release API:		${Github_Tag_URL} | ||||||
| 固件格式-框架:		$(GET_VARIABLE AutoBuild_Firmware= ${Default_Variable}) | 固件格式-框架:		$(GET_VARIABLE AutoBuild_Firmware ${Default_Variable}) | ||||||
| 固件名称-框架:		$(GET_VARIABLE Egrep_Firmware= ${Default_Variable}) | 固件名称-框架:		$(GET_VARIABLE Egrep_Firmware ${Default_Variable}) | ||||||
| 默认下载地址:		${Github_Release_URL} | 默认下载地址:		${Github_Release_URL} | ||||||
| 固件保存位置:           ${FW_SAVE_PATH} | 固件保存位置:           ${FW_SAVE_PATH} | ||||||
| 固件格式:		${Firmware_Type} | 固件格式:		${Firmware_Type} | ||||||
|  | @ -79,7 +70,24 @@ EOF | ||||||
| 	[[ ${TARGET_PROFILE} == x86_64 ]] && { | 	[[ ${TARGET_PROFILE} == x86_64 ]] && { | ||||||
| 		echo "引导模式:		${x86_64_Boot}" | 		echo "引导模式:		${x86_64_Boot}" | ||||||
| 	} | 	} | ||||||
| 	exit 0 | 	EXIT 2 | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | EXIT() { | ||||||
|  | 	local RUN_TYPE | ||||||
|  | 	case $1 in | ||||||
|  | 	0) | ||||||
|  | 		RUN_TYPE="[OK] " | ||||||
|  | 	;; | ||||||
|  | 	1) | ||||||
|  | 		RUN_TYPE="[ERROR] " | ||||||
|  | 	;; | ||||||
|  | 	*) | ||||||
|  | 		RUN_TYPE="[UNKNOWN] " | ||||||
|  | 	;; | ||||||
|  | 	esac | ||||||
|  | 	echo "[$(date "+%Y-%m-%d-%H:%M:%S")] ${RUN_TYPE}AutoUpdate 运行结束 ..." >> ${log_Path}/AutoUpdate.log | ||||||
|  | 	exit | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| RANDOM() { | RANDOM() { | ||||||
|  | @ -124,7 +132,7 @@ LOAD_VARIABLE() { | ||||||
| 	done | 	done | ||||||
| 	[[ -z ${TARGET_PROFILE} && -n ${Default_Device} ]] && TARGET_PROFILE="${Default_Device}" | 	[[ -z ${TARGET_PROFILE} && -n ${Default_Device} ]] && TARGET_PROFILE="${Default_Device}" | ||||||
| 	[[ -z ${TARGET_PROFILE} ]] && TARGET_PROFILE="$(jsonfilter -e '@.model.id' < /etc/board.json | tr ',' '_')" | 	[[ -z ${TARGET_PROFILE} ]] && TARGET_PROFILE="$(jsonfilter -e '@.model.id' < /etc/board.json | tr ',' '_')" | ||||||
| 	[[ -z ${TARGET_PROFILE} ]] && TIME r "获取设备名称失败,无法执行更新!" && exit 1 | 	[[ -z ${TARGET_PROFILE} ]] && TIME r "获取设备名称失败,无法执行更新!" && EXIT 1 | ||||||
| 	[[ -z ${CURRENT_Version} ]] && CURRENT_Version=未知 | 	[[ -z ${CURRENT_Version} ]] && CURRENT_Version=未知 | ||||||
| 	[[ -z ${FW_SAVE_PATH} ]] && FW_SAVE_PATH=/tmp/Downloads | 	[[ -z ${FW_SAVE_PATH} ]] && FW_SAVE_PATH=/tmp/Downloads | ||||||
| 	Github_Release_URL="${Github}/releases/download/AutoUpdate" | 	Github_Release_URL="${Github}/releases/download/AutoUpdate" | ||||||
|  | @ -145,7 +153,7 @@ LOAD_VARIABLE() { | ||||||
| 		;; | 		;; | ||||||
| 		*) | 		*) | ||||||
| 			TIME r "暂不支持当前固件格式!" | 			TIME r "暂不支持当前固件格式!" | ||||||
| 			exit 1 | 			EXIT 1 | ||||||
| 		;; | 		;; | ||||||
| 		esac | 		esac | ||||||
| 	;; | 	;; | ||||||
|  | @ -155,20 +163,20 @@ LOAD_VARIABLE() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| EDIT_VARIABLE() { | EDIT_VARIABLE() { | ||||||
| 	local Mode=$1 | 	local Mode="$1" | ||||||
| 	shift | 	shift | ||||||
| 	[[ ! -f $1 ]] && TIME r "未检测到定义文件: [$1] !" && exit 1 | 	[[ ! -f $1 ]] && TIME r "未检测到定义文件: [$1] !" && EXIT 1 | ||||||
| 	case "${Mode}" in | 	case "${Mode}" in | ||||||
| 	edit) | 	edit) | ||||||
|     	[[ $# != 3 ]] && SHELL_HELP 1 $* |     	[[ $# != 3 ]] && SHELL_HELP | ||||||
| 		if [[ -z $(GET_VARIABLE ${2}= $1) ]];then | 		if [[ -z $(GET_VARIABLE $2 $1) ]];then | ||||||
| 			echo -e "\n$2=$3" >> $1 | 			echo -e "\n$2=$3" >> $1 | ||||||
| 		else | 		else | ||||||
| 			sed -i "s?$(GET_VARIABLE ${2}= $1)?$3?g" $1 | 			sed -i "s?$(GET_VARIABLE ${2}= $1)?$3?g" $1 | ||||||
| 		fi | 		fi | ||||||
| 		;; | 		;; | ||||||
| 	rm) | 	rm) | ||||||
| 	    [[ $# != 2 ]] && SHELL_HELP 1 $* | 	    [[ $# != 2 ]] && SHELL_HELP | ||||||
| 		sed -i "/${2}=/d" $1 | 		sed -i "/${2}=/d" $1 | ||||||
| 	;; | 	;; | ||||||
| 	esac | 	esac | ||||||
|  | @ -178,7 +186,7 @@ CHANGE_GITHUB() { | ||||||
| 	[[ ! $1 =~ https://github.com/ ]] && { | 	[[ ! $1 =~ https://github.com/ ]] && { | ||||||
| 		TIME r "ERROR Github URL: $1" | 		TIME r "ERROR Github URL: $1" | ||||||
| 		TIME r "错误的 Github 地址,示例: https://github.com/Hyy2001X/AutoBuild-Actions" | 		TIME r "错误的 Github 地址,示例: https://github.com/Hyy2001X/AutoBuild-Actions" | ||||||
| 		exit 1 | 		EXIT 1 | ||||||
| 	} | 	} | ||||||
| 	UCI_Github_URL=$(uci get autoupdate.@common[0].github 2>/dev/null) | 	UCI_Github_URL=$(uci get autoupdate.@common[0].github 2>/dev/null) | ||||||
| 	[[ -n ${UCI_Github_URL} && ! ${UCI_Github_URL} == $1 ]] && { | 	[[ -n ${UCI_Github_URL} && ! ${UCI_Github_URL} == $1 ]] && { | ||||||
|  | @ -192,11 +200,11 @@ CHANGE_GITHUB() { | ||||||
| 	} || { | 	} || { | ||||||
| 		TIME y "当前输入的地址与原地址相同,无需修改!" | 		TIME y "当前输入的地址与原地址相同,无需修改!" | ||||||
| 	} | 	} | ||||||
| 	exit 0 | 	EXIT 0 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CHANGE_BOOT() { | CHANGE_BOOT() { | ||||||
| 	[[ -z $1 ]] && SHELL_HELP 1 $* | 	[[ -z $1 ]] && SHELL_HELP | ||||||
| 	case "$1" in | 	case "$1" in | ||||||
| 	UEFI | Legacy) | 	UEFI | Legacy) | ||||||
| 		EDIT_VARIABLE edit ${Custom_Variable} x86_64_Boot $1 | 		EDIT_VARIABLE edit ${Custom_Variable} x86_64_Boot $1 | ||||||
|  | @ -207,20 +215,20 @@ CHANGE_BOOT() { | ||||||
| 	;; | 	;; | ||||||
| 	*) | 	*) | ||||||
| 		TIME r "错误的参数: [$1],当前支持的选项: [UEFI/Legacy] !" | 		TIME r "错误的参数: [$1],当前支持的选项: [UEFI/Legacy] !" | ||||||
| 		exit 1 | 		EXIT 1 | ||||||
| 	;; | 	;; | ||||||
| 	esac | 	esac | ||||||
| 	exit 0 | 	EXIT 0 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| GET_VARIABLE() { | GET_VARIABLE() { | ||||||
| 	[[ $# != 2 ]] && SHELL_HELP 1 $* | 	[[ $# != 2 ]] && SHELL_HELP | ||||||
| 	[[ ! -f $2 ]] && TIME "未检测到定义文件: [$2] !" && exit 1 | 	[[ ! -f $2 ]] && TIME "未检测到定义文件: [$2] !" && EXIT 1 | ||||||
| 	echo -e "$(grep "$1" $2 | cut -c$(echo $1 | wc -c)-200 | awk 'NR==1')" | 	echo -e "$(grep "$1=" $2 | grep -v "#" | awk 'NR==1' | sed -r "s/$1=(.*)/\1/")" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| UPDATE_SCRIPT() { | UPDATE_SCRIPT() { | ||||||
| 	[[ $# != 2 ]] && SHELL_HELP 1 $* | 	[[ $# != 2 ]] && SHELL_HELP | ||||||
| 	TIME b "脚本保存目录: $1" | 	TIME b "脚本保存目录: $1" | ||||||
| 	TIME b "下载地址: $2" | 	TIME b "下载地址: $2" | ||||||
| 	TIME "开始更新 AutoUpdate 脚本,请耐心等待..." | 	TIME "开始更新 AutoUpdate 脚本,请耐心等待..." | ||||||
|  | @ -228,7 +236,7 @@ UPDATE_SCRIPT() { | ||||||
| 	wget -q --tries 3 --timeout 5 $2 -O /tmp/AutoUpdate.sh | 	wget -q --tries 3 --timeout 5 $2 -O /tmp/AutoUpdate.sh | ||||||
| 	if [[ $? == 0 ]];then | 	if [[ $? == 0 ]];then | ||||||
| 		mv -f /tmp/AutoUpdate.sh $1 | 		mv -f /tmp/AutoUpdate.sh $1 | ||||||
| 		[[ ! $? == 0 ]] && TIME r "AutoUpdate 脚本更新失败!" && exit 1 | 		[[ ! $? == 0 ]] && TIME r "AutoUpdate 脚本更新失败!" && EXIT 1 | ||||||
| 		chmod +x $1/AutoUpdate.sh | 		chmod +x $1/AutoUpdate.sh | ||||||
| 		NEW_Version=$(egrep -o "V[0-9].+" $1/AutoUpdate.sh | awk 'END{print}') | 		NEW_Version=$(egrep -o "V[0-9].+" $1/AutoUpdate.sh | awk 'END{print}') | ||||||
| 		Banner_Version=$(egrep -o "V[0-9]+.[0-9].+" /etc/banner) | 		Banner_Version=$(egrep -o "V[0-9]+.[0-9].+" /etc/banner) | ||||||
|  | @ -237,26 +245,26 @@ UPDATE_SCRIPT() { | ||||||
| 	else | 	else | ||||||
| 		TIME r "AutoUpdate 脚本更新失败,请检查网络后重试!" | 		TIME r "AutoUpdate 脚本更新失败,请检查网络后重试!" | ||||||
| 	fi | 	fi | ||||||
| 	exit | 	EXIT | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CHECK_DEPENDS() { | CHECK_DEPENDS() { | ||||||
| 	TITLE | 	TITLE | ||||||
| 	local PKG | 	local PKG | ||||||
| 	echo -e "\n软件包		状态" | 	echo -e "\n软件包		状态" | ||||||
| 	for PKG in $(echo $*) | 	while [[ $1 ]];do | ||||||
| 	do | 		if [[ $1 =~ : ]];then | ||||||
| 		if [[ ${PKG} =~ : ]];then | 			[[ $(echo $1 | cut -d ":" -f1) == ${TARGET_BOARD} ]] && { | ||||||
| 			[[ $(echo ${PKG} | cut -d ":" -f1) == ${TARGET_BOARD} ]] && { | 				PKG="$(echo $1 | cut -d ":" -f2)" | ||||||
| 				PKG="$(echo ${PKG} | cut -d ":" -f2)" |  | ||||||
| 				echo -e "${PKG}		$(CHECK_PKG ${PKG})" | 				echo -e "${PKG}		$(CHECK_PKG ${PKG})" | ||||||
| 			} | 			} | ||||||
| 		else | 		else | ||||||
| 			echo -e "${PKG}		$(CHECK_PKG ${PKG})" | 			echo -e "$1		$(CHECK_PKG $1)" | ||||||
| 		fi | 		fi | ||||||
|  | 		shift | ||||||
| 	done | 	done | ||||||
| 	TIME y "测试结束,若某项结果为 false,请手动安装该软件包!" | 	TIME y "测试结束,若某项测试结果为 [false],请手动 [opkg install] 安装该软件包!" | ||||||
| 	exit 0 | 	EXIT 0 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| CHECK_UPDATES() { | CHECK_UPDATES() { | ||||||
|  | @ -267,11 +275,11 @@ CHECK_UPDATES() { | ||||||
| 	[[ ! $? == 0 ]] || [[ ! -f ${FW_SAVE_PATH}/Github_Tags ]] && { | 	[[ ! $? == 0 ]] || [[ ! -f ${FW_SAVE_PATH}/Github_Tags ]] && { | ||||||
| 		[[ $1 == check ]] && echo "获取失败" > /tmp/Cloud_Version | 		[[ $1 == check ]] && echo "获取失败" > /tmp/Cloud_Version | ||||||
| 		TIME r "检查更新失败,请稍后重试!" | 		TIME r "检查更新失败,请稍后重试!" | ||||||
| 		exit 1 | 		EXIT 1 | ||||||
| 	} | 	} | ||||||
| 	eval X=$(GET_VARIABLE Egrep_Firmware= ${Default_Variable}) | 	eval X=$(GET_VARIABLE Egrep_Firmware ${Default_Variable}) | ||||||
| 	FW_Name=$(egrep -o "${X}" ${FW_SAVE_PATH}/Github_Tags | awk 'END {print}') | 	FW_Name=$(egrep -o "${X}" ${FW_SAVE_PATH}/Github_Tags | awk 'END {print}') | ||||||
| 	[[ -z ${FW_Name} ]] && TIME "云端固件名称获取失败!" && exit 1 | 	[[ -z ${FW_Name} ]] && TIME "云端固件名称获取失败!" && EXIT 1 | ||||||
| 	CLOUD_Firmware_Version=$(echo ${FW_Name} | egrep -o "R[0-9].*20[0-9]+") | 	CLOUD_Firmware_Version=$(echo ${FW_Name} | egrep -o "R[0-9].*20[0-9]+") | ||||||
| 	SHA5BIT=$(echo ${FW_Name} | egrep -o "[a-zA-Z0-9]+.${Firmware_Type}" | sed -r "s/(.*).${Firmware_Type}/\1/") | 	SHA5BIT=$(echo ${FW_Name} | egrep -o "[a-zA-Z0-9]+.${Firmware_Type}" | sed -r "s/(.*).${Firmware_Type}/\1/") | ||||||
| 	let Size="$(grep -n "${FW_Name}" ${FW_SAVE_PATH}/Github_Tags | tail -1 | cut -d : -f 1)-4" | 	let Size="$(grep -n "${FW_Name}" ${FW_SAVE_PATH}/Github_Tags | tail -1 | cut -d : -f 1)-4" | ||||||
|  | @ -303,7 +311,7 @@ PREPARE_UPGRADES() { | ||||||
| 			unset Proxy_Echo | 			unset Proxy_Echo | ||||||
| 		} | 		} | ||||||
| 		[[ $1 =~ path= ]] && { | 		[[ $1 =~ path= ]] && { | ||||||
| 			[ -z "$(echo $1 | cut -d "=" -f2)" ] && TIME r "固件保存目录不能为空!" && exit 1 | 			[ -z "$(echo $1 | cut -d "=" -f2)" ] && TIME r "固件保存目录不能为空!" && EXIT 1 | ||||||
| 			FW_SAVE_PATH=$(echo $1 | cut -d "=" -f2) | 			FW_SAVE_PATH=$(echo $1 | cut -d "=" -f2) | ||||||
| 			TIME g "自定义固件保存目录: ${FW_SAVE_PATH}" | 			TIME g "自定义固件保存目录: ${FW_SAVE_PATH}" | ||||||
| 		} | 		} | ||||||
|  | @ -352,7 +360,7 @@ PREPARE_UPGRADES() { | ||||||
| 	CHECK_UPDATES continue | 	CHECK_UPDATES continue | ||||||
| 	[[ -z ${CLOUD_Firmware_Version} ]] && { | 	[[ -z ${CLOUD_Firmware_Version} ]] && { | ||||||
| 		TIME r "云端固件信息获取失败!" | 		TIME r "云端固件信息获取失败!" | ||||||
| 		exit 1 | 		EXIT 1 | ||||||
| 	} | 	} | ||||||
| 	[[ ${Proxy_Mode} == 1 ]] && { | 	[[ ${Proxy_Mode} == 1 ]] && { | ||||||
| 		FW_URL="${FW_Proxy_URL}" | 		FW_URL="${FW_Proxy_URL}" | ||||||
|  | @ -373,12 +381,12 @@ EOF | ||||||
| 	if [[ ${CURRENT_Version} == ${CLOUD_Firmware_Version} ]];then | 	if [[ ${CURRENT_Version} == ${CLOUD_Firmware_Version} ]];then | ||||||
| 		[[ ${AutoUpdate_Mode} == 1 ]] && { | 		[[ ${AutoUpdate_Mode} == 1 ]] && { | ||||||
| 			TIME y "已是最新版本,无需更新!" | 			TIME y "已是最新版本,无需更新!" | ||||||
| 			exit 0 | 			EXIT 0 | ||||||
| 		} | 		} | ||||||
| 		[[ ! ${Force_Mode} == 1 ]] && { | 		[[ ! ${Force_Mode} == 1 ]] && { | ||||||
| 			TIME && read -p "已是最新版本,是否继续更新固件?[Y/n]:" Choose | 			TIME && read -p "已是最新版本,是否继续更新固件?[Y/n]:" Choose | ||||||
| 		} || Choose=Y | 		} || Choose=Y | ||||||
| 		[[ ! ${Choose} =~ [Yy] ]] && exit 0 | 		[[ ! ${Choose} =~ [Yy] ]] && EXIT 0 | ||||||
| 	fi | 	fi | ||||||
| 	Retry_Times=5 | 	Retry_Times=5 | ||||||
| 	TIME "正在下载固件,请耐心等待..." | 	TIME "正在下载固件,请耐心等待..." | ||||||
|  | @ -394,7 +402,7 @@ EOF | ||||||
| 			} | 			} | ||||||
| 		if [[ ${Retry_Times} == 0 ]];then | 		if [[ ${Retry_Times} == 0 ]];then | ||||||
| 			TIME r "固件下载失败,请检查网络后重试!" | 			TIME r "固件下载失败,请检查网络后重试!" | ||||||
| 			exit 1 | 			EXIT 1 | ||||||
| 		else | 		else | ||||||
| 			${Wget_Head} --tries 3 --timeout 5 "${FW_URL}/${FW_Name}" -O ${FW_SAVE_PATH}/${FW_Name} | 			${Wget_Head} --tries 3 --timeout 5 "${FW_URL}/${FW_Name}" -O ${FW_SAVE_PATH}/${FW_Name} | ||||||
| 			[[ $? == 0 ]] && TIME y "固件下载成功!" && break | 			[[ $? == 0 ]] && TIME y "固件下载成功!" && break | ||||||
|  | @ -410,7 +418,7 @@ EOF | ||||||
| 			TIME y "解压成功,固件已解压到: ${FW_SAVE_PATH}/${FW_Name}!" | 			TIME y "解压成功,固件已解压到: ${FW_SAVE_PATH}/${FW_Name}!" | ||||||
| 		} || { | 		} || { | ||||||
| 			TIME r "固件解压失败,请检查相关依赖或更换固件保存目录!" | 			TIME r "固件解压失败,请检查相关依赖或更换固件保存目录!" | ||||||
| 			exit 1 | 			EXIT 1 | ||||||
| 		} | 		} | ||||||
| 	;; | 	;; | ||||||
| 	esac | 	esac | ||||||
|  | @ -421,7 +429,7 @@ EOF | ||||||
| 	} || { | 	} || { | ||||||
| 		TIME b "[Test Mode] 执行: ${Upgrade_Option} ${FW_SAVE_PATH}/${FW_Name}" | 		TIME b "[Test Mode] 执行: ${Upgrade_Option} ${FW_SAVE_PATH}/${FW_Name}" | ||||||
| 		TIME b "[Test Mode] 测试模式运行完毕!" | 		TIME b "[Test Mode] 测试模式运行完毕!" | ||||||
| 		exit 0 | 		EXIT 0 | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -431,8 +439,8 @@ DO_UPGRADE() { | ||||||
| 	$* | 	$* | ||||||
| 	[[ $? -ne 0 ]] && { | 	[[ $? -ne 0 ]] && { | ||||||
| 		TIME r "固件刷写失败,请尝试手动更新固件!" | 		TIME r "固件刷写失败,请尝试手动更新固件!" | ||||||
| 		exit 1 | 		EXIT 1 | ||||||
| 	} || exit 0 | 	} || EXIT 0 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| REMOVE_FW_CACHE() { | REMOVE_FW_CACHE() { | ||||||
|  | @ -445,24 +453,20 @@ REMOVE_FW_CACHE() { | ||||||
| 	;; | 	;; | ||||||
| 	normal) | 	normal) | ||||||
| 		TIME y "固件下载缓存清理完成!" | 		TIME y "固件下载缓存清理完成!" | ||||||
| 		exit 0 | 		EXIT 0 | ||||||
| 	;; | 	;; | ||||||
| 	esac | 	esac | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| export Version=V6.0.7 |  | ||||||
| export log_Path=/tmp |  | ||||||
| export Upgrade_Command=sysupgrade |  | ||||||
| export Default_Variable=/etc/AutoBuild/Default_Variable |  | ||||||
| export Custom_Variable=/etc/AutoBuild/Custom_Variable |  | ||||||
| 
 | 
 | ||||||
| [ ! -f ${Custom_Variable} ] && touch ${Custom_Variable} | AutoUpdate_Main() { | ||||||
| LOAD_VARIABLE ${Default_Variable} ${Custom_Variable} | 	[ ! -f ${Custom_Variable} ] && touch ${Custom_Variable} | ||||||
|  | 	LOAD_VARIABLE ${Default_Variable} ${Custom_Variable} | ||||||
| 
 | 
 | ||||||
| [[ -z $* ]] && PREPARE_UPGRADES $* | 	[[ -z $* ]] && PREPARE_UPGRADES $* | ||||||
| [[ $* =~ path= && ! $* =~ -x && ! $* =~ -U ]] && PREPARE_UPGRADES $* | 	[[ $1 =~ path= && ! $* =~ -x && ! $* =~ -U ]] && PREPARE_UPGRADES $* | ||||||
| 
 | 
 | ||||||
| while [[ $1 ]];do | 	while [[ $1 ]];do | ||||||
| 		case "$1" in | 		case "$1" in | ||||||
| 		-V) | 		-V) | ||||||
| 			shift | 			shift | ||||||
|  | @ -475,16 +479,16 @@ while [[ $1 ]];do | ||||||
| 				[[ ${Cloud_Script_Version} ]] && echo "${Cloud_Script_Version}" || echo "未知" | 				[[ ${Cloud_Script_Version} ]] && echo "${Cloud_Script_Version}" || echo "未知" | ||||||
| 			;; | 			;; | ||||||
| 			esac | 			esac | ||||||
| 		exit 0 | 			EXIT 0 | ||||||
| 		;; | 		;; | ||||||
| 		--clean) | 		--clean) | ||||||
| 			REMOVE_FW_CACHE normal $* | 			REMOVE_FW_CACHE normal $* | ||||||
| 		;; | 		;; | ||||||
| 		--check) | 		--check) | ||||||
| 		CHECK_DEPENDS curl wget x86:gzip | 			CHECK_DEPENDS x86:gzip curl wget  | ||||||
| 		;; | 		;; | ||||||
| 	-H | --help) | 		--help) | ||||||
| 		SHELL_HELP 0 1 $* | 			SHELL_HELP | ||||||
| 		;; | 		;; | ||||||
| 		-L | --list) | 		-L | --list) | ||||||
| 			SHOW_VARIABLE | 			SHOW_VARIABLE | ||||||
|  | @ -493,7 +497,7 @@ while [[ $1 ]];do | ||||||
| 			CHANGE_GITHUB $2 | 			CHANGE_GITHUB $2 | ||||||
| 		;; | 		;; | ||||||
| 		-B) | 		-B) | ||||||
| 		[[ ! ${TARGET_PROFILE} == x86_64 ]] && TIME r "该参数仅适用于 x86_64 设备!" && exit 1 | 			[[ ! ${TARGET_PROFILE} == x86_64 ]] && TIME r "该参数仅适用于 x86_64 设备!" && EXIT 1 | ||||||
| 			CHANGE_BOOT $2 | 			CHANGE_BOOT $2 | ||||||
| 		;; | 		;; | ||||||
| 		-x) | 		-x) | ||||||
|  | @ -501,19 +505,19 @@ while [[ $1 ]];do | ||||||
| 				[[ $1 == -P || $1 == --proxy ]] && Proxy_Mode=1 | 				[[ $1 == -P || $1 == --proxy ]] && Proxy_Mode=1 | ||||||
| 				if [[ ${Proxy_Mode} == 1 && $1 =~ url= ]];then | 				if [[ ${Proxy_Mode} == 1 && $1 =~ url= ]];then | ||||||
| 					TIME r "参数冲突: [$0 $*],[-P,--proxy] 与 [url=] 不能同时存在!" | 					TIME r "参数冲突: [$0 $*],[-P,--proxy] 与 [url=] 不能同时存在!" | ||||||
| 				exit 1 | 					EXIT 1 | ||||||
| 				fi | 				fi | ||||||
| 				if [[ ! $1 =~ url= ]];then | 				if [[ ! $1 =~ url= ]];then | ||||||
| 						Script_URL=https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh | 						Script_URL=https://raw.githubusercontent.com/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh | ||||||
| 				else | 				else | ||||||
| 					[[ $1 =~ url= ]] && { | 					[[ $1 =~ url= ]] && { | ||||||
| 				[[ -z $(echo $1 | cut -d "=" -f2) ]] && TIME r "脚本地址不能为空!" && exit 1 | 					[[ -z $(echo $1 | cut -d "=" -f2) ]] && TIME r "脚本地址不能为空!" && EXIT 1 | ||||||
| 						Script_URL="$(echo $1 | cut -d "=" -f2)" | 						Script_URL="$(echo $1 | cut -d "=" -f2)" | ||||||
| 						TIME "使用自定义脚本地址: ${Script_URL}" | 						TIME "使用自定义脚本地址: ${Script_URL}" | ||||||
| 					} | 					} | ||||||
| 				fi | 				fi | ||||||
| 				[[ $1 =~ path= ]] && { | 				[[ $1 =~ path= ]] && { | ||||||
| 				[ -z "$(echo $1 | cut -d "=" -f2)" ] && TIME r "保存路径不能为空!" && exit 1 | 					[ -z "$(echo $1 | cut -d "=" -f2)" ] && TIME r "保存路径不能为空!" && EXIT 1 | ||||||
| 					SH_SAVE_PATH="$(echo $1 | cut -d "=" -f2)" | 					SH_SAVE_PATH="$(echo $1 | cut -d "=" -f2)" | ||||||
| 				} | 				} | ||||||
| 				shift | 				shift | ||||||
|  | @ -526,46 +530,47 @@ while [[ $1 ]];do | ||||||
| 			PREPARE_UPGRADES $* | 			PREPARE_UPGRADES $* | ||||||
| 		;; | 		;; | ||||||
| 		--corn) | 		--corn) | ||||||
| 		[[ $# != 3 ]] && SHELL_HELP 1 $* | 			[[ $# != 3 ]] && SHELL_HELP | ||||||
| 			shift | 			shift | ||||||
| 			while [[ $1 ]];do | 			while [[ $1 ]];do | ||||||
| 				[[ $1 =~ task= ]] && Task="$(echo $1 | cut -d "=" -f2)" | 				[[ $1 =~ task= ]] && Task="$(echo $1 | cut -d "=" -f2)" | ||||||
| 				Time="$1" | 				Time="$1" | ||||||
| 				shift | 				shift | ||||||
| 			done | 			done | ||||||
| 		[[ -z ${Task} || -z ${Time} ]] && SHELL_HELP 1 $* | 			[[ -z ${Task} || -z ${Time} ]] && SHELL_HELP | ||||||
| 			echo -e "\n${Time} bash $0 $Task" >> /etc/crontabs/root | 			echo -e "\n${Time} bash $0 $Task" >> /etc/crontabs/root | ||||||
| 			/etc/init.d/cron restart | 			/etc/init.d/cron restart | ||||||
| 			TIME y "已设置计划任务: [${Time} bash $0 $Task]" | 			TIME y "已设置计划任务: [${Time} bash $0 $Task]" | ||||||
| 		exit 0 | 			EXIT 0 | ||||||
| 		;; | 		;; | ||||||
| 	--corn-del) | 		--corn-rm) | ||||||
| 		[ ! -f /etc/crontabs/root ] && exit 1 | 			[ ! -f /etc/crontabs/root ] && EXIT 1 | ||||||
| 			sed -i '/AutoUpdate/d' /etc/crontabs/root >/dev/null 2>&1 | 			sed -i '/AutoUpdate/d' /etc/crontabs/root >/dev/null 2>&1 | ||||||
| 			TIME y "已删除所有 AutoUpdate 相关计划任务!" | 			TIME y "已删除所有 AutoUpdate 相关计划任务!" | ||||||
| 			/etc/init.d/cron restart | 			/etc/init.d/cron restart | ||||||
| 		exit 0 | 			EXIT 0 | ||||||
| 		;; | 		;; | ||||||
| 		-U) | 		-U) | ||||||
| 			CHECK_UPDATES check | 			CHECK_UPDATES check | ||||||
| 		exit 0 | 			EXIT 0 | ||||||
| 		;; | 		;; | ||||||
| 		--var) | 		--var) | ||||||
| 			shift | 			shift | ||||||
| 		[[ $# != 1 ]] && SHELL_HELP 1 $* | 			[[ $# != 1 ]] && SHELL_HELP | ||||||
| 		SHOW_VARIABLE=$(GET_VARIABLE "$1=" ${Custom_Variable}) | 			SHOW_VARIABLE=$(GET_VARIABLE "$1" ${Custom_Variable}) | ||||||
| 		[[ -z ${SHOW_VARIABLE} ]] && SHOW_VARIABLE=$(GET_VARIABLE "$1=" ${Default_Variable}) | 			[[ -z ${SHOW_VARIABLE} ]] && SHOW_VARIABLE=$(GET_VARIABLE "$1" ${Default_Variable}) | ||||||
| 			echo "${SHOW_VARIABLE}" | 			echo "${SHOW_VARIABLE}" | ||||||
| 		exit | 			EXIT | ||||||
| 		;; | 		;; | ||||||
| 	--var-del) | 		--var-rm) | ||||||
| 			shift | 			shift | ||||||
| 		[[ $# != 1 ]] && SHELL_HELP 1 $* | 			[[ $# != 1 ]] && SHELL_HELP | ||||||
| 			EDIT_VARIABLE rm ${Custom_Variable} $1 | 			EDIT_VARIABLE rm ${Custom_Variable} $1 | ||||||
|  | 			EXIT | ||||||
| 		;; | 		;; | ||||||
| 		--bak) | 		--bak) | ||||||
| 			shift | 			shift | ||||||
| 		[[ $# -lt 1 || $# -gt 2 ]] && TIME r "格式错误,示例: [bash $0 --bak /mnt/sda1 Openwrt_Backups.tar.gz]" && exit 1 | 			[[ $# -lt 1 || $# -gt 2 ]] && TIME r "格式错误,示例: [bash $0 --bak /mnt/sda1 Openwrt_Backups.tar.gz]" && EXIT 1 | ||||||
| 			[[ $# == 2 ]] && { | 			[[ $# == 2 ]] && { | ||||||
| 				[[ ! -d $1 ]] && mkdir -p $1 | 				[[ ! -d $1 ]] && mkdir -p $1 | ||||||
| 				FILE="$1/$2" | 				FILE="$1/$2" | ||||||
|  | @ -581,27 +586,48 @@ while [[ $1 ]];do | ||||||
| 			sysupgrade -b "${FILE}" >/dev/null 2>&1 | 			sysupgrade -b "${FILE}" >/dev/null 2>&1 | ||||||
| 			[ $? == 0 ] && { | 			[ $? == 0 ] && { | ||||||
| 				TIME y "备份成功!" | 				TIME y "备份成功!" | ||||||
| 		} || TIME r "备份文件创建失败,请更换保存目录!" | 			} || TIME r "备份文件创建失败,请尝试更换保存目录!" | ||||||
| 		exit | 			EXIT | ||||||
| 		;; | 		;; | ||||||
| 		--log) | 		--log) | ||||||
|  | 			shift | ||||||
|  | 			[[ -z $1 ]] && { | ||||||
| 				[[ -f ${log_Path}/AutoUpdate.log ]] && { | 				[[ -f ${log_Path}/AutoUpdate.log ]] && { | ||||||
| 					TITLE && echo | 					TITLE && echo | ||||||
| 					cat ${log_Path}/AutoUpdate.log | 					cat ${log_Path}/AutoUpdate.log | ||||||
| 				} | 				} | ||||||
| 
 | 			} || { | ||||||
| 	;; | 				while [[ $1 ]];do | ||||||
| 	--log-path) | 					if [[ $1 =~ path= ]];then | ||||||
| 		shift | 						LOG_PATH="$(echo $1 | cut -d "=" -f2)" | ||||||
| 		[[ -z $* ]] && SHELL_HELP 1 $* |  | ||||||
| 						EDIT_VARIABLE rm ${Custom_Variable} log_Path | 						EDIT_VARIABLE rm ${Custom_Variable} log_Path | ||||||
| 		EDIT_VARIABLE edit ${Custom_Variable} log_Path $1 | 						EDIT_VARIABLE edit ${Custom_Variable} log_Path ${LOG_PATH} | ||||||
| 		[[ ! -d $1 ]] && mkdir -p $1 | 						[[ ! -d ${LOG_PATH} ]] && mkdir -p ${LOG_PATH} | ||||||
| 		TIME y "AutoUpdate 日志位置已修改为: $1/AutoUpdate.log" | 						TIME y "AutoUpdate 日志保存目录已修改为: ${LOG_PATH}" | ||||||
|  | 						EXIT | ||||||
|  | 					fi | ||||||
|  | 					[[ $1 == rm || $1 == del ]] && { | ||||||
|  | 						[[ -f ${log_Path}/AutoUpdate.log ]] && { | ||||||
|  | 							rm ${log_Path}/AutoUpdate.log | ||||||
|  | 						} | ||||||
|  | 					} | ||||||
|  | 					[[ ! $1 =~ path= && $1 != rm && $1 != del ]] && SHELL_HELP | ||||||
|  | 					EXIT | ||||||
|  | 				done | ||||||
|  | 			} | ||||||
| 		;; | 		;; | ||||||
| 		*) | 		*) | ||||||
| 		SHELL_HELP 1 $* | 			SHELL_HELP | ||||||
| 		;; | 		;; | ||||||
| 		esac | 		esac | ||||||
| 		shift | 		shift | ||||||
| done | 	done | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export Version=V6.1.0 | ||||||
|  | export log_Path=/tmp | ||||||
|  | export Upgrade_Command=sysupgrade | ||||||
|  | export Default_Variable=/etc/AutoBuild/Default_Variable | ||||||
|  | export Custom_Variable=/etc/AutoBuild/Custom_Variable | ||||||
|  | 
 | ||||||
|  | AutoUpdate_Main $* | ||||||
		Loading…
	
		Reference in New Issue