V5.7.1 新增参数 -xp: 更新 AutoUpdate.sh 脚本 (使用镜像加速)

This commit is contained in:
Hyy2001X 2021-05-06 21:12:01 +08:00
parent 454e514bf5
commit 1047ea5576
1 changed files with 47 additions and 38 deletions

View File

@ -3,33 +3,35 @@
# AutoBuild Module by Hyy2001 # AutoBuild Module by Hyy2001
# AutoUpdate for Openwrt # AutoUpdate for Openwrt
Version=V5.7 Version=V5.7.1
Shell_Helper() { Shell_Helper() {
cat <<EOF cat <<EOF
使用方法: $0 [<更新参数><更新附加参数>] 使用方法: $0 [<更新参数/复合参数] [-n] [-f] [-u] [-p] [-np] [-fp]
$0 [<设置参数>...] [-c] [-boot] <额外参数> $0 [<设置参数>...] [-c] [-b] <额外参数>
$0 [<其他>...] [-l] [-d] [-help] $0 [<其他>...] [-x] [-xp] [-l] [-lp] [-d] [-h]
更新参数: 更新参数:
-n 更新固件 [不保留配置] -n 更新固件 [不保留配置]
-np 更新固件 [不保留配置] (镜像加速)
-f 强制更新固件,即跳过版本号验证,自动下载以及安装必要软件包 [保留配置] -f 强制更新固件,即跳过版本号验证,自动下载以及安装必要软件包 [保留配置]
-u 适用于定时更新 LUCI 的参数 [保留配置] -u 适用于定时更新 LUCI 的参数 [保留配置]
更新附加参数:
-p 优先使用 [FastGit] 镜像加速
设置参数: 设置参数:
-c [额外参数:<Github 地址>] 更换 Github 检查更新以及固件下载地址 -c [额外参数:<Github 地址>] 更换 Github 地址
-b | -boot [额外参数:<引导方式 UEFI/Legacy>] 指定 x86 设备下载使用 UEFI/Legacy 引导的固件 [危险] -b [额外参数:<引导方式 UEFI/Legacy>] 指定 x86 设备下载使用 UEFI/Legacy 引导的固件 (危险)
其他: 其他:
-x | 更新 AutoUpdate.sh 脚本 -x 更新 AutoUpdate.sh 脚本
-l | -list 列出设备信息 -xp 更新 AutoUpdate.sh 脚本 (镜像加速)
-d | -del 清除固件下载缓存 -l 列出系统信息
-h | -help 打印帮助信息 -d 清理固件下载缓存
-h 打印帮助信息
复合/单参数:
-p 使用 [FastGit] 镜像加速
EOF EOF
exit 0 exit 0
} }
@ -48,7 +50,7 @@ AutoUpdate 版本: ${Version}
Github: ${Github} Github: ${Github}
Github Raw: ${Github_Raw} Github Raw: ${Github_Raw}
解析 API: ${Github_Tags} 解析 API: ${Github_Tags}
固件下载地址: ${Github_Download} 固件下载地址: ${Github_Release}
作者/仓库: ${Author} 作者/仓库: ${Author}
固件格式: ${Firmware_SFX} 固件格式: ${Firmware_SFX}
EOF EOF
@ -62,7 +64,7 @@ EOF
Install_Pkg() { Install_Pkg() {
PKG_NAME=$1 PKG_NAME=$1
if [[ ! "$(cat /tmp/Package_list)" =~ "${PKG_NAME}" ]];then if [[ ! "$(cat /tmp/Package_list)" =~ "${PKG_NAME}" ]];then
[[ "${Force_Update}" == "1" ]] || [[ "${AutoUpdate_Mode}" == "1" ]] && { [[ "${Force_Update}" == 1 ]] || [[ "${AutoUpdate_Mode}" == 1 ]] && {
Choose=Y Choose=Y
} || { } || {
TIME && read -p "未安装[${PKG_NAME}],是否执行安装?[Y/n]:" Choose TIME && read -p "未安装[${PKG_NAME}],是否执行安装?[Y/n]:" Choose
@ -99,14 +101,14 @@ Download_Path="/tmp/Downloads"
opkg list | awk '{print $1}' > /tmp/Package_list opkg list | awk '{print $1}' > /tmp/Package_list
CURRENT_Version="$(awk 'NR==1' /etc/openwrt_info)" CURRENT_Version="$(awk 'NR==1' /etc/openwrt_info)"
Github="$(awk 'NR==2' /etc/openwrt_info)" Github="$(awk 'NR==2' /etc/openwrt_info)"
Github_Download="${Github}/releases/download/AutoUpdate" Github_Release="${Github}/releases/download/AutoUpdate"
Author="${Github##*com/}" Author="${Github##*com/}"
Github_Raw="https://raw.githubusercontent.com/${Author}/master" CLOUD_Script="Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh"
CLOUD_Script="${Github_Raw}/Scripts/AutoUpdate.sh"
Github_Tags="https://api.github.com/repos/${Author}/releases/latest" Github_Tags="https://api.github.com/repos/${Author}/releases/latest"
Github_Raw="https://raw.githubusercontent.com"
DEFAULT_Device="$(awk 'NR==3' /etc/openwrt_info)" DEFAULT_Device="$(awk 'NR==3' /etc/openwrt_info)"
Firmware_Type="$(awk 'NR==4' /etc/openwrt_info)" Firmware_Type="$(awk 'NR==4' /etc/openwrt_info)"
_PROXY_URL="https://download.fastgit.org" _PROXY_Release="https://download.fastgit.org"
TMP_Available="$(df -m | grep "/tmp" | awk '{print $4}' | awk 'NR==1' | awk -F. '{print $1}')" TMP_Available="$(df -m | grep "/tmp" | awk '{print $4}' | awk 'NR==1' | awk -F. '{print $1}')"
Overlay_Available="$(df -h | grep ":/overlay" | awk '{print $4}' | awk 'NR==1')" Overlay_Available="$(df -h | grep ":/overlay" | awk '{print $4}' | awk 'NR==1')"
Retry_Times=4 Retry_Times=4
@ -150,12 +152,15 @@ if [[ -z "${Input_Option}" ]];then
Upgrade_Options="-q" Upgrade_Options="-q"
TIME && echo "执行: 保留配置更新固件" TIME && echo "执行: 保留配置更新固件"
else else
[[ "${Input_Option}" =~ p ]] && {
PROXY_Release="${_PROXY_Release}"
Github_Raw="https://raw.fastgit.org"
PROXY_ECHO="[FastGit] "
} || {
PROXY_ECHO=""
}
case ${Input_Option} in case ${Input_Option} in
-n | -f | -u | -np | -pn | -fp | -pf | -up | -pu | -p) -n | -f | -u | -p | -np | -pn | -fp | -pf | -up | -pu)
[[ "${Input_Option}" =~ p ]] && {
PROXY_URL="${_PROXY_URL}"
PROXY_ECHO="[FastGit] "
} || PROXY_ECHO=""
case ${Input_Option} in case ${Input_Option} in
-n | -np | -pn) -n | -np | -pn)
TIME && echo "${PROXY_ECHO}执行: 更新固件(不保留配置)" TIME && echo "${PROXY_ECHO}执行: 更新固件(不保留配置)"
@ -186,18 +191,18 @@ else
Shell_Helper Shell_Helper
fi fi
;; ;;
-l | -list) -l | -lp | -pl)
List_Info List_Info
;; ;;
-d | -del) -d)
rm -f ${Download_Path}/* rm -f ${Download_Path}/*
TIME && echo "固件下载缓存清理完成!" TIME && echo "固件下载缓存清理完成!"
exit 0 exit 0
;; ;;
-h | -help) -h)
Shell_Helper Shell_Helper
;; ;;
-b | -boot) -b)
[[ -z "${Input_Other}" ]] && Shell_Helper [[ -z "${Input_Other}" ]] && Shell_Helper
case "${Input_Other}" in case "${Input_Other}" in
UEFI | Legacy) UEFI | Legacy)
@ -213,13 +218,17 @@ else
;; ;;
esac esac
;; ;;
-x) -x | -xp | -px)
CLOUD_Script=${Github_Raw}/Hyy2001X/AutoBuild-Actions/master/Scripts/AutoUpdate.sh
TIME && echo "${PROXY_ECHO}开始更新 AutoUpdate 脚本,请耐心等待..."
wget -q --tries 3 --timeout 5 ${CLOUD_Script} -O ${Download_Path}/AutoUpdate.sh wget -q --tries 3 --timeout 5 ${CLOUD_Script} -O ${Download_Path}/AutoUpdate.sh
if [[ $? == 0 ]];then if [[ $? == 0 ]];then
TIME && echo "AutoUpdate 脚本更新成功!"
rm /bin/AutoUpdate.sh rm /bin/AutoUpdate.sh
mv -f ${Download_Path}/AutoUpdate.sh /bin mv -f ${Download_Path}/AutoUpdate.sh /bin
chmod +x /bin/AutoUpdate.sh chmod +x /bin/AutoUpdate.sh
NEW_Version=$(egrep -o "V[0-9]+.[0-9]+" /bin/AutoUpdate.sh | awk 'NR==1')
TIME && echo "AutoUpdate [${Version}] > [${NEW_Version}]"
TIME && echo "AutoUpdate 脚本更新成功!"
exit 0 exit 0
else else
TIME && echo "AutoUpdate 脚本更新失败,请检查网络后重试!" TIME && echo "AutoUpdate 脚本更新失败,请检查网络后重试!"
@ -236,11 +245,11 @@ if [[ "$(cat /tmp/Package_list)" =~ "curl" ]];then
Google_Check=$(curl -I -s --connect-timeout 3 google.com -w %{http_code} | tail -n1) Google_Check=$(curl -I -s --connect-timeout 3 google.com -w %{http_code} | tail -n1)
[[ ! "$Google_Check" == 301 ]] && { [[ ! "$Google_Check" == 301 ]] && {
TIME && echo "Google 连接失败,尝试使用 [FastGit] 镜像加速!" TIME && echo "Google 连接失败,尝试使用 [FastGit] 镜像加速!"
PROXY_URL="${_PROXY_URL}" PROXY_Release="${_PROXY_Release}"
} }
else else
TIME && echo "无法确定网络环境,默认使用 [FastGit] 镜像加速!" TIME && echo "无法确定网络环境,默认使用 [FastGit] 镜像加速!"
PROXY_URL="${_PROXY_URL}" PROXY_Release="${_PROXY_Release}"
fi fi
[[ "${TMP_Available}" -lt "${Space_Min}" ]] && { [[ "${TMP_Available}" -lt "${Space_Min}" ]] && {
TIME && echo "/tmp 空间不足: [${Space_Min}M],无法执行更新!" TIME && echo "/tmp 空间不足: [${Space_Min}M],无法执行更新!"
@ -302,9 +311,9 @@ if [[ ! "${Force_Update}" == 1 ]];then
} }
fi fi
fi fi
[[ -n "${PROXY_URL}" ]] && Github_Download=${PROXY_URL}/${Author}/releases/download/AutoUpdate [[ -n "${PROXY_Release}" ]] && Github_Release=${PROXY_Release}/${Author}/releases/download/AutoUpdate
echo -e "\n云端固件名称: ${Firmware}" echo -e "\n云端固件名称: ${Firmware}"
echo "固件下载地址: ${Github_Download}" echo "固件下载地址: ${Github_Release}"
echo "固件保存位置: ${Download_Path}" echo "固件保存位置: ${Download_Path}"
[ ! -d "${Download_Path}" ] && mkdir -p ${Download_Path} [ ! -d "${Download_Path}" ] && mkdir -p ${Download_Path}
rm -f ${Download_Path}/* rm -f ${Download_Path}/*
@ -313,16 +322,16 @@ cd ${Download_Path}
while [ "${Retry_Times}" -ge 0 ]; while [ "${Retry_Times}" -ge 0 ];
do do
if [[ "${Retry_Times}" == 3 ]];then if [[ "${Retry_Times}" == 3 ]];then
[[ -z "${PROXY_URL}" ]] && { [[ -z "${PROXY_Release}" ]] && {
TIME && echo "正在尝试使用 [FastGit] 镜像加速下载..." TIME && echo "正在尝试使用 [FastGit] 镜像加速下载..."
Github_Download=${_PROXY_URL}/${Author}/releases/download/AutoUpdate Github_Release=${_PROXY_Release}/${Author}/releases/download/AutoUpdate
} }
fi fi
if [[ "${Retry_Times}" == 0 ]];then if [[ "${Retry_Times}" == 0 ]];then
TIME && echo "固件下载失败,请检查网络后重试!" TIME && echo "固件下载失败,请检查网络后重试!"
exit 1 exit 1
else else
wget -q --tries 1 --timeout 5 "${Github_Download}/${Firmware}" -O ${Firmware} wget -q --tries 1 --timeout 5 "${Github_Release}/${Firmware}" -O ${Firmware}
[[ $? == 0 ]] && break [[ $? == 0 ]] && break
fi fi
Retry_Times=$((${Retry_Times} - 1)) Retry_Times=$((${Retry_Times} - 1))
@ -331,7 +340,7 @@ do
done done
TIME && echo "固件下载成功!" TIME && echo "固件下载成功!"
TIME && echo "正在获取云端固件MD5,请耐心等待..." TIME && echo "正在获取云端固件MD5,请耐心等待..."
wget -q ${Github_Download}/${Firmware_Detail} -O ${Firmware_Detail} wget -q ${Github_Release}/${Firmware_Detail} -O ${Firmware_Detail}
[[ ! $? == 0 ]] && { [[ ! $? == 0 ]] && {
TIME && echo "MD5 获取失败,请检查网络后重试!" TIME && echo "MD5 获取失败,请检查网络后重试!"
exit 1 exit 1