diff --git a/Scripts/AutoBuild_DiyScript.sh b/Scripts/AutoBuild_DiyScript.sh index 04d7487..fb7f186 100755 --- a/Scripts/AutoBuild_DiyScript.sh +++ b/Scripts/AutoBuild_DiyScript.sh @@ -16,15 +16,30 @@ Diy_Core() { } Firmware-Diy() { + # 部分可调用变量如下 + # OP_Maintainer 源码作者 + # OP_REPO_NAME 仓库名称 + # OP_BRANCH 源码分支 + # TARGET_PROFILE 设备名称 + # TARGET_BOARD 设备架构 + # CustomFiles 仓库 /CustomFiles 路径 + # Scripts 仓库 /Scripts 路径 + # Home 源码存放位置,等同 ${GITHUB_WORKSPACE}/openwrt + # feeds_luci 等同 ${GITHUB_WORKSPACE}/openwrt/package/feeds/luci + # feeds_pkgs 等同 ${GITHUB_WORKSPACE}/openwrt/package/feeds/packages + # base_files 等同 ${GITHUB_WORKSPACE}/openwrt/package/base-files/files + case "${TARGET_PROFILE}" in d-team_newifi-d2) - Copy CustomFiles/mac80211.sh package/kernel/mac80211/files/lib/wifi - Copy CustomFiles/system_${TARGET_PROFILE} package/base-files/files/etc/config system + patch -i ${CustomFiles}/mac80211_d-team_newifi-d2.patch package/kernel/mac80211/files/lib/wifi/mac80211.sh + Copy ${CustomFiles}/system_d-team_newifi-d2 ${base_files}/etc/config system ;; esac case "${OP_Maintainer}/${OP_REPO_NAME}:${OP_BRANCH}" in coolsnowwolf/lede:master) - sed -i "s?/bin/login?/usr/libexec/login.sh?g" package/feeds/packages/ttyd/files/ttyd.config + sed -i "s?/bin/login?/usr/libexec/login.sh?g" ${feeds_pkgs}/ttyd/files/ttyd.config + sed -i "/dns_caching_dns/d" $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc + echo " option dns_caching_dns '223.5.5.5,114.114.114.114'" >> $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc ;; esac } \ No newline at end of file diff --git a/Scripts/AutoBuild_Function.sh b/Scripts/AutoBuild_Function.sh index a80f167..dcb2358 100755 --- a/Scripts/AutoBuild_Function.sh +++ b/Scripts/AutoBuild_Function.sh @@ -26,7 +26,7 @@ Firmware-Diy_Before() { CURRENT_Version="${zzz_Default_Version}-${Compile_Date}" ;; immortalwrt) - Version_File=package/base-files/files/etc/openwrt_release + Version_File=${base_files}/etc/openwrt_release CURRENT_Version="${Openwrt_Version_Head}${Compile_Date}" ;; *) @@ -67,7 +67,7 @@ Firmware-Diy_Before() { REGEX_Firmware='AutoBuild-${OP_REPO_NAME}-${TARGET_PROFILE}-R[0-9.]+-[0-9]+-[0-9a-z]+.${Firmware_Type}' ;; esac - cat >> VARIABLE_Main <> ${Home}/VARIABLE_Main <> VARIABLE_FILE <> ${Home}/VARIABLE_FILE <> VARIABLE_FILE - echo -e "### SYS-VARIABLE LIST ###\n$(cat VARIABLE_FILE)\n" + echo "$(cat ${Home}/VARIABLE_Main)" >> ${Home}/VARIABLE_FILE + echo -e "### SYS-VARIABLE LIST ###\n$(cat ${Home}/VARIABLE_FILE)\n" } Firmware-Diy_Main() { Firmware-Diy_Before TIME "[Firmware-Diy_Main]" - mkdir -p package/base-files/files/etc/AutoBuild - [ -f VARIABLE_Main ] && cp VARIABLE_Main package/base-files/files/etc/AutoBuild/Default_Variable - Copy CustomFiles/Depends/Custom_Variable package/base-files/files/etc/AutoBuild - chmod +x -R ${GITHUB_WORKSPACE}/Scripts - chmod 777 -R ${GITHUB_WORKSPACE}/CustomFiles + source ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE + mkdir -p ${base_files}/etc/AutoBuild + [ -f ${GITHUB_WORKSPACE}/openwrt/VARIABLE_Main ] && cp VARIABLE_Main ${base_files}/etc/AutoBuild/Default_Variable + Copy ${CustomFiles}/Depends/Custom_Variable ${base_files}/etc/AutoBuild + chmod +x -R ${Scripts} + chmod 777 -R ${CustomFiles} [[ ${Load_CustomPackages_List} == true ]] && { - bash -n ${GITHUB_WORKSPACE}/Scripts/AutoBuild_ExtraPackages.sh + bash -n ${Scripts}/AutoBuild_ExtraPackages.sh [[ ! $? == 0 ]] && TIME "AutoBuild_ExtraPackages.sh syntax error,skip ..." || { - . ${GITHUB_WORKSPACE}/Scripts/AutoBuild_ExtraPackages.sh + . ${Scripts}/AutoBuild_ExtraPackages.sh } } [[ ${INCLUDE_AutoBuild_Features} == true ]] && { - Copy Scripts/AutoBuild_Tools.sh package/base-files/files/bin - Copy Scripts/AutoUpdate.sh package/base-files/files/bin + Copy ${Scripts}/AutoBuild_Tools.sh ${base_files}/bin + Copy ${Scripts}/AutoUpdate.sh ${base_files}/bin AddPackage git lean luci-app-autoupdate Hyy2001X main } [[ ${INCLUDE_Argon} == true ]] && { @@ -141,27 +147,25 @@ Firmware-Diy_Main() { } [[ -n ${Before_IP_Address} ]] && Default_LAN_IP="${Before_IP_Address}" [[ -n ${Default_LAN_IP} && ${Default_LAN_IP} =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]] && { - Old_IP_Address=$(awk -F '[="]+' '/ipaddr:-/{print $3}' package/base-files/files/bin/config_generate | awk 'NR==1') + Old_IP_Address=$(awk -F '[="]+' '/ipaddr:-/{print $3}' ${base_files}/bin/config_generate | awk 'NR==1') if [[ ! ${Default_LAN_IP} == ${Old_IP_Address} ]];then TIME "Setting default IP Address to ${Default_LAN_IP} ..." - sed -i "s/${Old_IP_Address}/${Default_LAN_IP}/g" package/base-files/files/bin/config_generate + sed -i "s/${Old_IP_Address}/${Default_LAN_IP}/g" ${base_files}/bin/config_generate fi } [[ ${INCLUDE_DRM_I915} == true && ${TARGET_BOARD} == x86 ]] && { - Copy CustomFiles/Depends/DRM-I915 target/linux/x86 + Copy ${CustomFiles}/Depends/DRM-I915 target/linux/x86 for X in $(ls -1 target/linux/x86 | grep "config-"); do echo -e "\n$(cat target/linux/x86/DRM-I915)" >> target/linux/x86/${X}; done } - [ -f package/base-files/files/bin/AutoUpdate.sh ] && { - AutoUpdate_Version=$(egrep -o "V[0-9].+" package/base-files/files/bin/AutoUpdate.sh | awk 'END{print}') + [ -f ${base_files}/bin/AutoUpdate.sh ] && { + AutoUpdate_Version=$(egrep -o "V[0-9].+" ${base_files}/bin/AutoUpdate.sh | awk 'END{print}') } || AutoUpdate_Version=OFF - Copy CustomFiles/Depends/profile package/base-files/files/etc - Copy CustomFiles/Depends/base-files-essential package/base-files/files/lib/upgrade/keep.d + Copy ${CustomFiles}/Depends/profile ${base_files}/etc + Copy ${CustomFiles}/Depends/base-files-essential ${base_files}/lib/upgrade/keep.d case "${OP_Maintainer}" in coolsnowwolf) - sed -i "/dns_caching_dns/d" $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc - echo " option dns_caching_dns '223.5.5.5,114.114.114.114'" >> $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc - Copy CustomFiles/Depends/coremark.sh $(PKG_Finder d "package feeds" coremark) - Copy CustomFiles/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo + Copy ${CustomFiles}/Depends/coremark.sh $(PKG_Finder d "package feeds" coremark) + Copy ${CustomFiles}/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo AddPackage git other helloworld fw876 master sed -i 's/143/143,8080/' $(PKG_Finder d package luci-app-ssr-plus)/root/etc/init.d/shadowsocksr sed -i "s?iptables?#iptables?g" ${Version_File} @@ -170,21 +174,21 @@ Firmware-Diy_Main() { immortalwrt) sed -i "/dns_caching_dns/d" $(PKG_Finder d "package feeds" luci-app-turboacc)/root/etc/config/turboacc echo " option dns_caching_dns '223.5.5.5,114.114.114.114'" >> $(PKG_Finder d "package feeds" luci-app-turboacc)/root/etc/config/turboacc - Copy CustomFiles/Depends/openwrt_release_${OP_Maintainer} package/base-files/files/etc openwrt_release - Copy CustomFiles/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo + Copy ${CustomFiles}/Depends/openwrt_release_${OP_Maintainer} ${base_files}/etc openwrt_release + Copy ${CustomFiles}/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo sed -i "s?ImmortalWrt?ImmortalWrt @ ${Author} [${Display_Date}]?g" ${Version_File} ;; esac case "${OP_Maintainer}" in immortalwrt) - Copy CustomFiles/Depends/banner $(PKG_Finder d package default-settings)/files openwrt_banner + Copy ${CustomFiles}/Depends/banner $(PKG_Finder d package default-settings)/files openwrt_banner sed -i "s?By?By ${Author}?g" $(PKG_Finder d package default-settings)/files/openwrt_banner sed -i "s?Openwrt?Openwrt ${CURRENT_Version} / AutoUpdate ${AutoUpdate_Version}?g" $(PKG_Finder d package default-settings)/files/openwrt_banner ;; *) - Copy CustomFiles/Depends/banner package/base-files/files/etc - sed -i "s?By?By ${Author}?g" package/base-files/files/etc/banner - sed -i "s?Openwrt?Openwrt ${CURRENT_Version} / AutoUpdate ${AutoUpdate_Version}?g" package/base-files/files/etc/banner + Copy ${CustomFiles}/Depends/banner ${base_files}/etc + sed -i "s?By?By ${Author}?g" ${base_files}/etc/banner + sed -i "s?Openwrt?Openwrt ${CURRENT_Version} / AutoUpdate ${AutoUpdate_Version}?g" ${base_files}/etc/banner ;; esac TIME "[Firmware-Diy_Main] All done !" @@ -192,7 +196,7 @@ Firmware-Diy_Main() { Firmware-Diy_Other() { TIME "[Firmware-Diy_Other]" - source ./VARIABLE_FILE + source ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE case "${PKG_Compatible}" in 19.07) OP_BRANCH=19.07 @@ -211,12 +215,11 @@ Firmware-Diy_Other() { case "${OP_BRANCH}" in 19.07 | 21.02 | main) [[ ${OP_BRANCH} == main ]] && OP_BRANCH=21.02 - Copy CustomFiles/Patches/0003-upx-ucl-${OP_BRANCH}.patch ./ + Copy ${CustomFiles}/Patches/0003-upx-ucl-${OP_BRANCH}.patch ./ cat 0003-upx-ucl-${OP_BRANCH}.patch | patch -p1 > /dev/null 2>&1 # AddPackage svn feeds/packages golang coolsnowwolf/packages/trunk/lang TIME "Starting to convert zh-cn translation files to zh_Hans ..." - Copy Scripts/Convert_Translation.sh package - cd ./package && bash ./Convert_Translation.sh && cd .. + cd package && ${Scripts}/Convert_Translation.sh && cd - ;; *) TIME "Current branch: [${OP_BRANCH}] is not supported,skip..." @@ -238,7 +241,7 @@ Firmware-Diy_Other() { Firmware-Diy_End() { TIME "[Firmware-Diy_End]" - source ./VARIABLE_FILE + source ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE mkdir -p bin/Firmware sha256sums="${Firmware_Path}/sha256sums" cd ${Firmware_Path} @@ -317,15 +320,13 @@ Get_sha256() { } Get_Variable() { - grep "$1" ${Home}/VARIABLE_FILE | cut -c$(echo $1 | wc -c)-200 | cut -d ":" -f2 + grep "$1" ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE | cut -c$(echo $1 | wc -c)-200 | cut -d ":" -f2 } Get_Branches() { - Folder="$(pwd)" - [[ -n $1 ]] && Folder="$1" - git -C "${Folder}" rev-parse --abbrev-ref HEAD | grep -v HEAD || \ - git -C "${Folder}" describe --exact-match HEAD || \ - git -C "${Folder}" rev-parse HEAD + git -C $(pwd) rev-parse --abbrev-ref HEAD | grep -v HEAD || \ + git -C $(pwd) describe --exact-match HEAD || \ + git -C $(pwd) rev-parse HEAD } TIME() { @@ -357,20 +358,21 @@ AddPackage() { ;; esac PKG_DIR=$2 + [[ ! ${PKG_DIR} =~ ${GITHUB_WORKSPACE} ]] && PKG_DIR=package/${PKG_DIR} PKG_NAME=$3 REPO_URL="https://github.com/$4" REPO_BRANCH=$5 [[ ${REPO_URL} =~ "${OP_Maintainer}/${OP_REPO_NAME}" ]] && return 0 - mkdir -p package/${PKG_DIR} || { - TIME "Can't create download dir: [package/${PKG_DIR}]" + mkdir -p ${PKG_DIR} || { + TIME "Can't create download dir: [${PKG_DIR}] ..." return 0 } - [[ -d package/${PKG_DIR}/${PKG_NAME} ]] && { + [[ -d ${PKG_DIR}/${PKG_NAME} ]] && { TIME "Removing old package: [${PKG_NAME}] ..." - rm -rf package/${PKG_DIR}/${PKG_NAME} + rm -rf ${PKG_DIR}/${PKG_NAME} } - TIME "Checking out package [${PKG_NAME}] to package/${PKG_DIR} ..." + TIME "Checking out package [${PKG_NAME}] to ${PKG_DIR} ..." case "${PKG_PROTO}" in git) [[ -z ${REPO_BRANCH} ]] && { @@ -385,21 +387,26 @@ AddPackage() { ;; esac [[ -f ${PKG_NAME}/Makefile || -n $(ls -A ${PKG_NAME}) ]] && { - mv -f "${PKG_NAME}" "package/${PKG_DIR}" - } || TIME "Package: ${PKG_NAME} failed to download" + mv -f "${PKG_NAME}" "${PKG_DIR}" + } || TIME "Failed to download package ${PKG_NAME} ..." } Copy() { - [[ $# -lt 2 ]] && { - TIME "Error options: [$#] [$*] !" + [[ ! $# =~ [23] ]] && { + TIME "Error options: [$#] [$*]" return 0 } - [[ ! -f ${GITHUB_WORKSPACE}/$1 ]] && [[ ! -d ${GITHUB_WORKSPACE}/$1 ]] && { - TIME "Unable to access CustomFiles/$1,skip ..." + [[ ! -f $1 ]] && [[ ! -d $1 ]] && { + TIME "$1: No such file or directory ..." return 0 } - [[ ! -d ${GITHUB_WORKSPACE}/openwrt/$2 ]] && mkdir -p "${GITHUB_WORKSPACE}/openwrt/$2" - [[ -n $3 ]] && RENAME="$3" || RENAME="" - TIME "Copying $1 to $2 ${RENAME} ..." - cp -a "${GITHUB_WORKSPACE}/$1" "${GITHUB_WORKSPACE}/openwrt/$2/${RENAME}" + [[ ! -d ${GITHUB_WORKSPACE}/openwrt/$2 ]] && mkdir -p ${GITHUB_WORKSPACE}/openwrt/$2 + + if [[ -z $3 ]];then + TIME "Copying $1 to $2 ..." + cp -a $1 ${GITHUB_WORKSPACE}/openwrt/$2 + else + TIME "Copy and renaming $1 to $2/$3 ..." + cp -a $1 ${GITHUB_WORKSPACE}/openwrt/$2/$3 + fi } \ No newline at end of file