This commit is contained in:
Hyy2001X 2022-03-23 20:59:28 +08:00
parent 3785c2f78f
commit e92a7be84d
2 changed files with 140 additions and 122 deletions

View File

@ -6,17 +6,17 @@ Firmware_Diy_Core() {
Author=AUTO
Author_URL=AUTO
Default_FLAG=AUTO
Default_Flag=AUTO
Default_IP="192.168.1.1"
Banner_Message="Powered by AutoBuild-Actions"
Default_Title="Powered by AutoBuild-Actions"
Short_Firmware_Date=true
Checkout_Virtual_Images=false
Firmware_Format=AUTO
REGEX_Skip_Checkout="packages|buildinfo|sha256sums|manifest|kernel|rootfs|factory"
Short_Fw_Date=true
x86_Full_Images=false
Fw_Format=false
Regex_Skip="packages|buildinfo|sha256sums|manifest|kernel|rootfs|factory|itb|profile"
INCLUDE_AutoBuild_Features=true
INCLUDE_Original_OpenWrt_Compatible=false
AutoBuild_Features=true
Compatible=false
}
Firmware_Diy() {
@ -31,7 +31,7 @@ Firmware_Diy() {
# ${TARGET_BOARD} 设备架构
# ${TARGET_FLAG} 固件名称后缀
# ${Home} OpenWrt 源码位置
# ${WORK} OpenWrt 源码位置
# ${CONFIG_FILE} 使用的配置文件名称
# ${FEEDS_CONF} OpenWrt 源码目录下的 feeds.conf.default 文件
# ${CustomFiles} 仓库中的 /CustomFiles 绝对路径
@ -57,13 +57,13 @@ Firmware_Diy() {
# AddPackage svn other ddnsto linkease/nas-packages/trunk/network/services
AddPackage git other helloworld fw876 master
sed -i 's/143/143,8080,8443/' $(PKG_Finder d package luci-app-ssr-plus)/root/etc/init.d/shadowsocksr
patch < ${CustomFiles}/Patches/revert_remove-alterId-config.patch -p1 -d ${Home}
patch < ${CustomFiles}/Patches/fix_ntfs3_antfs_conflict.patch -p1 -d ${Home}
patch < ${CustomFiles}/Patches/fix_aria2_autocreate_path.patch -p1 -d ${Home}
patch < ${CustomFiles}/Patches/revert_remove-alterId-config.patch -p1 -d ${WORK}
patch < ${CustomFiles}/Patches/fix_ntfs3_antfs_conflict.patch -p1 -d ${WORK}
patch < ${CustomFiles}/Patches/fix_aria2_autocreate_path.patch -p1 -d ${WORK}
case "${TARGET_PROFILE}" in
d-team_newifi-d2)
patch < ${CustomFiles}/${TARGET_PROFILE}_mac80211.patch -p1 -d ${Home}
patch < ${CustomFiles}/${TARGET_PROFILE}_mac80211.patch -p1 -d ${WORK}
Copy ${CustomFiles}/${TARGET_PROFILE}_system ${BASE_FILES}/etc/config system
sed -i "/DEVICE_COMPAT_VERSION := 1.1/d" target/linux/ramips/image/mt7621.mk
Copy ${CustomFiles}/fake-automount $(PKG_Finder d "package" automount)/files 15-automount
@ -72,8 +72,8 @@ Firmware_Diy() {
Copy ${CustomFiles}/fake-automount $(PKG_Finder d "package" automount)/files 15-automount
;;
x86_64)
AddPackage git other openwrt-passwall xiaorouji main
AddPackage git other luci-app-passwall2 xiaorouji main
AddPackage git other openwrt-passwall xiaorouji packages
AddPackage git other openwrt-passwall xiaorouji luci
rm -rf packages/lean/autocore
AddPackage git lean autocore-modify Hyy2001X master
;;

View File

@ -4,16 +4,16 @@
Firmware_Diy_Before() {
ECHO "[Firmware_Diy_Before] Starting ..."
Home="${GITHUB_WORKSPACE}/openwrt"
WORK="${GITHUB_WORKSPACE}/openwrt"
CONFIG_TEMP="${GITHUB_WORKSPACE}/openwrt/.config"
CD ${Home}
CD ${WORK}
Firmware_Diy_Core
[[ ${Short_Firmware_Date} == true ]] && Compile_Date="$(echo ${Compile_Date} | cut -c1-8)"
[[ ${Short_Fw_Date} == true ]] && Compile_Date="$(echo ${Compile_Date} | cut -c1-8)"
Github="$(grep "https://github.com/[a-zA-Z0-9]" ${GITHUB_WORKSPACE}/.git/config | cut -c8-100 | sed 's/^[ \t]*//g')"
[[ -z ${Author} || ${Author} == AUTO ]] && Author="$(echo "${Github}" | cut -d "/" -f4)"
OP_AUTHOR="$(echo "${REPO_URL}" | cut -d "/" -f4)"
OP_REPO="$(echo "${REPO_URL}" | cut -d "/" -f5)"
OP_BRANCH="$(GET_Branch)"
OP_BRANCH="$(Get_Branch)"
if [[ ${OP_BRANCH} =~ (master|main) ]]
then
OP_VERSION_HEAD="R$(date +%y.%m)-"
@ -41,44 +41,46 @@ Firmware_Diy_Before() {
x86_Test="$(egrep -o "CONFIG_TARGET.*Generic=y" ${CONFIG_TEMP} | sed -r 's/CONFIG_TARGET_(.*)_Generic=y/\1/')"
[[ -z ${x86_Test} ]] && break
done
[[ ${x86_Test} == x86_64 ]] && {
if [[ ${x86_Test} == x86_64 ]]
then
TARGET_PROFILE=x86_64
} || {
else
TARGET_PROFILE="$(egrep -o "CONFIG_TARGET.*DEVICE.*=y" ${CONFIG_TEMP} | sed -r 's/.*DEVICE_(.*)=y/\1/')"
}
fi
[[ -z ${TARGET_PROFILE} ]] && ECHO "Unable to get [TARGET_PROFILE] !"
TARGET_BOARD="$(awk -F '[="]+' '/TARGET_BOARD/{print $2}' ${CONFIG_TEMP})"
TARGET_SUBTARGET="$(awk -F '[="]+' '/TARGET_SUBTARGET/{print $2}' ${CONFIG_TEMP})"
[[ -z ${Firmware_Format} || ${Firmware_Format} =~ (false|AUTO) ]] && {
if [[ -z ${Fw_MFormat} || ${Fw_MFormat} =~ (false|AUTO) ]]
then
case "${TARGET_BOARD}" in
ramips | reltek | ath* | ipq* | bcm47xx | bmips | kirkwood | mediatek)
Firmware_Format=bin
Fw_MFormat=bin
;;
rockchip | x86 | bcm27xx | mxs | sunxi | zynq)
Firmware_Format="$(if_IMG)"
Fw_MFormat="$(gz_Check)"
;;
mvebu)
case "${TARGET_SUBTARGET}" in
cortexa53 | cortexa72)
Firmware_Format="$(if_IMG)"
Fw_MFormat="$(gz_Check)"
;;
esac
;;
octeon | oxnas | pistachio)
Firmware_Format=tar
Fw_MFormat=tar
;;
esac
}
fi
[[ ${Author_URL} != false && ${Author_URL} == AUTO ]] && Author_URL="${Github}"
[[ ${Author_URL} == false ]] && unset Author_URL
if [[ ${Default_FLAG} == AUTO ]]
if [[ ${Default_Flag} == AUTO ]]
then
TARGET_FLAG=${CONFIG_FILE/${TARGET_PROFILE}-/}
[[ ${TARGET_FLAG} =~ ${TARGET_PROFILE} || -z ${TARGET_FLAG} || ${TARGET_FLAG} == ${CONFIG_FILE} ]] && TARGET_FLAG=Full
else
if [[ ! ${Default_FLAG} =~ (\"|=|-|_|\.|\#|\|) && ${Default_FLAG} =~ [a-zA-Z0-9] ]]
if [[ ! ${Default_Flag} =~ (\"|=|-|_|\.|\#|\|) && ${Default_Flag} =~ [a-zA-Z0-9] ]]
then
TARGET_FLAG="${Default_FLAG}"
TARGET_FLAG="${Default_Flag}"
fi
fi
if [[ ! ${Tempoary_FLAG} =~ (\"|=|-|_|\.|\#|\|) && ${Tempoary_FLAG} =~ [a-zA-Z0-9] ]]
@ -87,29 +89,29 @@ Firmware_Diy_Before() {
fi
case "${TARGET_BOARD}" in
x86)
AutoBuild_Firmware="AutoBuild-${OP_REPO}-${TARGET_PROFILE}-${OP_VERSION}-BOOT-${TARGET_FLAG}-SHA256.FORMAT"
AutoBuild_Fw="AutoBuild-${OP_REPO}-${TARGET_PROFILE}-${OP_VERSION}-BOOT-${TARGET_FLAG}-SHA256.FORMAT"
;;
*)
AutoBuild_Firmware="AutoBuild-${OP_REPO}-${TARGET_PROFILE}-${OP_VERSION}-${TARGET_FLAG}-SHA256.FORMAT"
AutoBuild_Fw="AutoBuild-${OP_REPO}-${TARGET_PROFILE}-${OP_VERSION}-${TARGET_FLAG}-SHA256.FORMAT"
;;
esac
cat >> ${GITHUB_ENV} <<EOF
Home=${Home}
WORK=${WORK}
CONFIG_TEMP=${CONFIG_TEMP}
INCLUDE_AutoBuild_Features=${INCLUDE_AutoBuild_Features}
INCLUDE_Original_OpenWrt_Compatible=${INCLUDE_Original_OpenWrt_Compatible}
Checkout_Virtual_Images=${Checkout_Virtual_Images}
AutoBuild_Firmware=${AutoBuild_Firmware}
AutoBuild_Features=${AutoBuild_Features}
Compatible=${Compatible}
x86_Full_Images=${x86_Full_Images}
AutoBuild_Fw=${AutoBuild_Fw}
CustomFiles=${GITHUB_WORKSPACE}/CustomFiles
Scripts=${GITHUB_WORKSPACE}/Scripts
BASE_FILES=${GITHUB_WORKSPACE}/openwrt/package/base-files/files
FEEDS_LUCI=${GITHUB_WORKSPACE}/openwrt/package/feeds/luci
FEEDS_PKG=${GITHUB_WORKSPACE}/openwrt/package/feeds/packages
Banner_Message="${Banner_Message}"
REGEX_Skip_Checkout="${REGEX_Skip_Checkout}"
Default_Title="${Default_Title}"
Regex_Skip="${Regex_Skip}"
Version_File=${Version_File}
Firmware_Format=${Firmware_Format}
FEEDS_CONF=${Home}/feeds.conf.default
Fw_MFormat=${Fw_MFormat}
FEEDS_CONF=${WORK}/feeds.conf.default
Author_URL=${Author_URL}
ENV_FILE=${GITHUB_ENV}
@ -121,9 +123,9 @@ EOF
Firmware_Diy_Main() {
ECHO "[Firmware_Diy_Main] Starting ..."
CD ${Home}
CD ${WORK}
chmod 777 -R ${Scripts} ${CustomFiles}
if [[ ${INCLUDE_AutoBuild_Features} == true ]]
if [[ ${AutoBuild_Features} == true ]]
then
MKDIR ${BASE_FILES}/etc/AutoBuild
touch ${BASE_FILES}/etc/AutoBuild/Default_Variable ${BASE_FILES}/etc/AutoBuild/Custom_Variable
@ -168,7 +170,7 @@ EOF
Copy ${CustomFiles}/Depends/base-files-essential ${BASE_FILES}/lib/upgrade/keep.d
case "${OP_AUTHOR}/${OP_REPO}" in
coolsnowwolf/lede)
Copy ${CustomFiles}/Depends/coremark.sh ${Home}/$(PKG_Finder d "package feeds" coremark)
Copy ${CustomFiles}/Depends/coremark.sh ${WORK}/$(PKG_Finder d "package feeds" coremark)
sed -i '\/etc\/firewall.user/d;/exit 0/d' ${Version_File}
cat >> ${Version_File} <<EOF
@ -214,36 +216,38 @@ EOF
esac
sed -i "s?By?By ${Author}?g" ${CustomFiles}/Depends/banner
sed -i "s?Openwrt?Openwrt ${OP_VERSION} / AutoUpdate ${AutoUpdate_Version}?g" ${CustomFiles}/Depends/banner
if [[ -n ${Banner_Message} ]]
if [[ -n ${Default_Title} ]]
then
if [[ -n ${TARGET_FLAG} ]]
then
sed -i "s?Powered by AutoBuild-Actions?${Banner_Message} @ ${TARGET_FLAG}?g" ${CustomFiles}/Depends/banner
sed -i "s?Powered by AutoBuild-Actions?${Default_Title} @ ${TARGET_FLAG}?g" ${CustomFiles}/Depends/banner
else
sed -i "s?Powered by AutoBuild-Actions?${Banner_Message}?g" ${CustomFiles}/Depends/banner
sed -i "s?Powered by AutoBuild-Actions?${Default_Title}?g" ${CustomFiles}/Depends/banner
fi
fi
case "${OP_AUTHOR}/${OP_REPO}" in
immortalwrt/immortalwrt)
Copy ${CustomFiles}/Depends/banner ${Home}/$(PKG_Finder d package default-settings)/files openwrt_banner
Copy ${CustomFiles}/Depends/banner ${WORK}/$(PKG_Finder d package default-settings)/files openwrt_banner
;;
*)
Copy ${CustomFiles}/Depends/banner ${BASE_FILES}/etc
;;
esac
fi
[[ -n ${Tempoary_IP} ]] && {
if [[ -n ${Tempoary_IP} ]]
then
ECHO "Using Tempoary IP Address: ${Tempoary_IP} ..."
Default_IP="${Tempoary_IP}"
}
[[ -n ${Default_IP} && ${Default_IP} =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]] && {
fi
if [[ -n ${Default_IP} && ${Default_IP} =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]]
then
Old_IP=$(awk -F '[="]+' '/ipaddr:-/{print $3}' ${BASE_FILES}/bin/config_generate | awk 'NR==1')
if [[ ! ${Default_IP} == ${Old_IP} ]]
then
ECHO "Setting default IP Address to ${Default_IP} ..."
sed -i "s/${Old_IP}/${Default_IP}/g" ${BASE_FILES}/bin/config_generate
fi
}
fi
for X in $(ls -1 target/linux/generic | grep "config-")
do
sed -i '/CONFIG_FAT_DEFAULT_IOCHARSET/d' target/linux/generic/${X}
@ -254,20 +258,20 @@ EOF
Firmware_Diy_Other() {
ECHO "[Firmware_Diy_Other] Starting ..."
CD ${Home}
case "${INCLUDE_Original_OpenWrt_Compatible}" in
CD ${WORK}
case "${Compatible}" in
19.07)
OP_BRANCH=19.07
Force_mode=1
INCLUDE_Original_OpenWrt_Compatible=true
Compatible=true
;;
21.02)
OP_BRANCH=21.02
Force_mode=1
INCLUDE_Original_OpenWrt_Compatible=true
Compatible=true
;;
esac
if [[ ${INCLUDE_Original_OpenWrt_Compatible} == true ]]
if [[ ${Compatible} == true ]]
then
if [[ ${OP_AUTHOR} =~ (openwrt|[Ll]ienol) || ${Force_mode} == 1 ]]
then
@ -282,7 +286,7 @@ CONFIG_PACKAGE_dnsmasq-full=y
# CONFIG_PACKAGE_wpad-wolfssl is not set
CONFIG_PACKAGE_wpad-openssl=y
EOF
Copy ${CustomFiles}/Patches/fix_upx-ucl-${OP_BRANCH}.patch ${Home}
Copy ${CustomFiles}/Patches/fix_upx-ucl-${OP_BRANCH}.patch ${WORK}
cat fix_upx-ucl-${OP_BRANCH}.patch | patch -p1 > /dev/null 2>&1
AddPackage svn feeds/packages golang coolsnowwolf/packages/trunk/lang
ECHO "Starting to convert zh-cn translation files to zh_Hans ..."
@ -309,103 +313,108 @@ EOF
Firmware_Diy_End() {
ECHO "[Firmware_Diy_End] Starting ..."
cd ${Home}
MKDIR ${Home}/bin/Firmware
Firmware_Path="${Home}/bin/targets/${TARGET_BOARD}/${TARGET_SUBTARGET}"
SHA256_File="${Firmware_Path}/sha256sums"
cd ${Firmware_Path}
echo -e "### FIRMWARE OUTPUT ###\n$(ls -1 | egrep -v "packages|buildinfo|sha256sums|manifest")\n"
cd ${WORK}
MKDIR ${WORK}/bin/Firmware
Fw_Path="${WORK}/bin/targets/${TARGET_BOARD}/${TARGET_SUBTARGET}"
cd ${Fw_Path}
echo -e "### FIRMWARE OUTPUT ###\n$(ls -1)\n"
case "${TARGET_BOARD}" in
x86)
[[ ${Checkout_Virtual_Images} == true ]] && {
Process_Firmware $(List_Format)
} || {
Process_Firmware ${Firmware_Format}
}
if [[ ${x86_Full_Images} == true ]]
then
Process_Fw $(List_MFormat)
else
Process_Fw ${Fw_MFormat}
fi
;;
*)
if [[ -n ${Firmware_Format} ]]
if [[ -n ${Fw_MFormat} ]]
then
Process_Firmware ${Firmware_Format}
Process_Fw ${Fw_MFormat}
else
Process_Firmware $(List_Format)
Process_Fw $(List_MFormat)
fi
;;
esac
[[ $(ls) =~ 'AutoBuild-' ]] && {
if [[ $(ls) =~ 'AutoBuild-' ]]
then
cd -
cp -a ${Firmware_Path}/AutoBuild-* bin/Firmware
}
cp -a ${Fw_Path}/AutoBuild-* bin/Firmware
fi
echo "[$(date "+%H:%M:%S")] Actions Avaliable: $(df -h | grep "/dev/root" | awk '{printf $4}')"
ECHO "[Firmware_Diy_End] Done"
}
Process_Firmware() {
Process_Fw() {
while [[ $1 ]];do
Process_Firmware_Core $1 $(List_Firmware $1)
Process_Fw_Core $1 $(List_Fw $1 | Regex)
shift
done
}
Process_Firmware_Core() {
Firmware_Format_Defined=$1
Process_Fw_Core() {
Fw_Format=$1
shift
while [[ $1 ]];do
Firmware=${AutoBuild_Firmware}
Fw=${AutoBuild_Fw}
case "${TARGET_BOARD}" in
x86)
[[ $1 =~ efi ]] && {
FW_Boot_Method=UEFI
} || FW_Boot_Method=BIOS
Firmware=${Firmware/BOOT/${FW_Boot_Method}}
[[ $1 =~ efi ]] && Fw_Boot=UEFI || Fw_Boot=BIOS
Fw=${Fw/BOOT/${Fw_Boot}}
;;
esac
Firmware=${Firmware/SHA256/$(Get_SHA256 $1)}
Firmware=${Firmware/FORMAT/${Firmware_Format_Defined}}
[[ -f $1 ]] && {
ECHO "Copying [$1] to [${Firmware}] ..."
cp -a $1 ${Firmware}
} || ECHO "Unable to access [${Firmware}] ..."
Fw=${Fw/SHA256/$(Get_sha256 $1)}
Fw=${Fw/FORMAT/${Fw_Format}}
if [[ -f $1 ]]
then
ECHO "Copying [$1] to [${Fw}] ..."
cp -a $1 ${Fw}
else
ECHO "Failed to copy [${Fw}] ..."
fi
shift
done
}
List_Firmware() {
[[ -z $* ]] && {
List_REGEX | while read X;do
List_Fw() {
if [[ -z $* ]]
then
for X in $(List_sha256);do
echo ${X} | cut -d "*" -f2
done
} || {
else
while [[ $1 ]];do
for X in $(echo $(List_REGEX));do
for X in $(List_sha256);do
[[ ${X} == *$1 ]] && echo "${X}" | cut -d "*" -f2
done
shift
done
}
fi
}
List_Format() {
echo "$(List_REGEX | cut -d "*" -f2 | cut -d "." -f2-3)" | sort | uniq
Regex() {
egrep -v "${Regex_Skip}"
}
List_REGEX() {
[[ -n ${REGEX_Skip_Checkout} ]] && {
egrep -v "${REGEX_Skip_Checkout}" ${SHA256_File} | tr -s '\n'
} || egrep -v "packages|buildinfo|sha256sums|manifest|kernel|rootfs|factory" ${SHA256_File} | tr -s '\n'
List_sha256() {
cat ${Fw_Path}/sha256sums 2> /dev/null | Regex | tr -s '\n'
}
Get_SHA256() {
List_REGEX | grep "$1" | cut -c1-5
List_MFormat() {
echo "$(List_sha256 | cut -d "*" -f2 | cut -d "." -f2-3)" | sort | uniq
}
GET_Branch() {
Get_sha256() {
List_sha256 | grep $1 | awk '{print $1}' | cut -c1-5
}
Get_Branch() {
git -C $(pwd) rev-parse --abbrev-ref HEAD | grep -v HEAD || \
git -C $(pwd) describe --exact-match HEAD || \
git -C $(pwd) rev-parse HEAD
}
if_IMG() {
gz_Check() {
[[ $(cat ${CONFIG_TEMP}) =~ CONFIG_TARGET_IMAGES_GZIP=y ]] && {
echo img.gz
} || echo img
@ -417,11 +426,12 @@ ECHO() {
PKG_Finder() {
local Result
[[ $# -ne 3 ]] && {
if [[ $# -ne 3 ]]
then
ECHO "Usage: PKG_Finder <f | d> Search_Path Target_Name/Target_Path"
return 0
}
Result=$(find $2 -name $3 -type $1 -exec echo {} \;)
fi
Result=$(find $2 -name $3 -type $1 -exec echo {} \; 2> /dev/null)
[[ -n ${Result} ]] && echo "${Result}"
}
@ -441,10 +451,11 @@ MKDIR() {
}
AddPackage() {
[[ $# -lt 4 ]] && {
if [[ $# -lt 4 ]]
then
ECHO "Syntax error: [$#] [$*]"
return 0
}
fi
PKG_PROTO=$1
case "${PKG_PROTO}" in
git | svn)
@ -463,17 +474,19 @@ AddPackage() {
[[ ${REPO_URL} =~ "${OP_AUTHOR}/${OP_REPO}" ]] && return 0
MKDIR ${PKG_DIR}
[[ -d ${PKG_DIR}/${PKG_NAME} ]] && {
if [[ -d ${PKG_DIR}/${PKG_NAME} ]]
then
ECHO "Removing old package: [${PKG_NAME}] ..."
rm -rf ${PKG_DIR}/${PKG_NAME}
}
fi
ECHO "Checking out package [${PKG_NAME}] to ${PKG_DIR} ..."
case "${PKG_PROTO}" in
git)
[[ -z ${REPO_BRANCH} ]] && {
if [[ -z ${REPO_BRANCH} ]]
then
ECHO "WARNING: Syntax missing <branch> ,using default branch: [master]"
REPO_BRANCH=master
}
fi
PKG_URL="$(echo ${REPO_URL}/${PKG_NAME} | sed s/[[:space:]]//g)"
git clone -b ${REPO_BRANCH} ${PKG_URL} ${PKG_NAME} > /dev/null 2>&1
;;
@ -481,21 +494,26 @@ AddPackage() {
svn checkout ${REPO_URL}/${PKG_NAME} ${PKG_NAME} > /dev/null 2>&1
;;
esac
[[ -f ${PKG_NAME}/Makefile || -n $(ls -A ${PKG_NAME}) ]] && {
if [[ -f ${PKG_NAME}/Makefile || -n $(ls -A ${PKG_NAME}) ]]
then
mv -f "${PKG_NAME}" "${PKG_DIR}"
[[ $? == 0 ]] && ECHO "Done"
} || ECHO "Failed to download package ${PKG_NAME} ..."
else
ECHO "Failed to download package ${PKG_NAME} ..."
fi
}
Copy() {
[[ ! $# =~ [23] ]] && {
if [[ ! $# =~ [23] ]]
then
ECHO "Syntax error: [$#] [$*]"
return 0
}
[[ ! -f $1 ]] && [[ ! -d $1 ]] && {
fi
if [[ ! -f $1 && ! -d $1 ]]
then
ECHO "$1: No such file or directory ..."
return 0
}
fi
MKDIR $2
if [[ -z $3 ]]
then