Openwrt-AutoBuild.yml 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361
  1. #=================================================
  2. # https://github.com/P3TERX/Actions-OpenWrt
  3. # Description: Build OpenWrt using GitHub Actions
  4. # Lisence: MIT
  5. # Author: P3TERX
  6. # Blog: https://p3terx.com
  7. #=================================================
  8. name: Build OpenWrt
  9. on:
  10. repository_dispatch:
  11. env:
  12. REPO_TOKEN: ${{ secrets.TOKEN_KIDDIN9 }}
  13. PPPOE_USERNAME: ${{ secrets.PPPOE_USERNAME }}
  14. PPPOE_PASSWD: ${{ secrets.PPPOE_PASSWD }}
  15. SCKEY: ${{ secrets.SCKEY }}
  16. TELEGRAM_TOKEN: ${{ secrets.TELEGRAM_TOKEN }}
  17. TELEGRAM_CHAT_ID: ${{ secrets.TELEGRAM_CHAT_ID }}
  18. SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
  19. DOCKER_ID: ${{ secrets.DOCKER_ID }}
  20. DOCKER_PASSWD: ${{ secrets.DOCKER_PASSWD }}
  21. TZ: Asia/Shanghai
  22. jobs:
  23. build:
  24. runs-on: Ubuntu-22.04
  25. name: Build ${{matrix.target}}
  26. strategy:
  27. fail-fast: false
  28. matrix:
  29. target: ["${{ github.event.client_payload.target }}"]
  30. steps:
  31. - name: Checkout
  32. uses: actions/checkout@main
  33. with:
  34. fetch-depth: 0
  35. # - name: Set up secret file
  36. # run: |
  37. # echo ${{ secrets.TELEGRAM_CHAT_ID }} | sed 's/./& /g'
  38. # echo ${{ secrets.TELEGRAM_TOKEN }} | sed 's/./& /g'
  39. - name: Load Settings.ini
  40. run: |
  41. echo ${{matrix.target}}
  42. source "${GITHUB_WORKSPACE}/devices/common/settings.ini"
  43. if [ -f "devices/${{matrix.target}}/settings.ini" ]; then
  44. source "${GITHUB_WORKSPACE}/devices/${{matrix.target}}/settings.ini"
  45. fi
  46. echo "REPO_URL=${REPO_URL}" >> $GITHUB_ENV
  47. echo "REPO_BRANCH=${REPO_BRANCH}" >> $GITHUB_ENV
  48. echo "CONFIG_FILE=${CONFIG_FILE}" >> $GITHUB_ENV
  49. echo "DIY_SH=${DIY_SH}" >> $GITHUB_ENV
  50. echo "FREE_UP_DISK=${FREE_UP_DISK}" >> $GITHUB_ENV
  51. echo "UPLOAD_BIN_DIR_FOR_ARTIFACT=${UPLOAD_BIN_DIR_FOR_ARTIFACT}" >> $GITHUB_ENV
  52. echo "UPLOAD_FIRMWARE_FOR_ARTIFACT=${UPLOAD_FIRMWARE_FOR_ARTIFACT}" >> $GITHUB_ENV
  53. echo "UPLOAD_FIRMWARE_FOR_RELEASE=${UPLOAD_FIRMWARE_FOR_RELEASE}" >> $GITHUB_ENV
  54. echo "UPLOAD_FIRMWARE_TO_COWTRANSFER=${UPLOAD_FIRMWARE_TO_COWTRANSFER}" >> $GITHUB_ENV
  55. echo "UPLOAD_FIRMWARE_TO_WETRANSFER=${UPLOAD_FIRMWARE_TO_WETRANSFER}" >> $GITHUB_ENV
  56. sed -i "1a REPO_TOKEN=${{ secrets.TOKEN_KIDDIN9 }}" ${GITHUB_WORKSPACE}/devices/common/diy.sh
  57. sed -i "1a TARGET=${{matrix.target}}" ${GITHUB_WORKSPACE}/devices/common/diy.sh
  58. if [ ${{matrix.target}} == "x86_64" ]; then
  59. echo "ARCH=linux/amd64" >> $GITHUB_ENV
  60. echo "MTARGET=x86_64" >> $GITHUB_ENV
  61. elif [ ${{matrix.target}} == "x86_generic" ]; then
  62. echo "ARCH=linux/amd32" >> $GITHUB_ENV
  63. echo "MTARGET=x86_generic" >> $GITHUB_ENV
  64. elif [[ ${{matrix.target}} =~ (armsr_armv8|qualcommax_ipq807x|mediatek_mt7622|mediatek_mt7981|mediatek_filogic|bcm27xx_bcm2710|qualcommax_ipq60xx|bcm4908_generic|sunxi_cortexa53) ]]; then
  65. echo "MTARGET=aarch64_cortex-a53" >> $GITHUB_ENV
  66. elif [[ ${{matrix.target}} =~ (ramips_mt7621|ramips_mt7620|ramips_mt76x8) ]]; then
  67. echo "MTARGET=mipsel_24kc" >> $GITHUB_ENV
  68. elif [[ ${{matrix.target}} == "ath79_nand" ]]; then
  69. echo "MTARGET=mips_24kc" >> $GITHUB_ENV
  70. elif [[ ${{matrix.target}} == "ipq50xx_arm" ]]; then
  71. echo "MTARGET=arm_cortex-a7" >> $GITHUB_ENV
  72. elif [[ ${{matrix.target}} =~ (ipq40xx_generic|bcm27xx_bcm2709|sunxi_cortexa7) ]]; then
  73. echo "MTARGET=arm_cortex-a7_neon-vfpv4" >> $GITHUB_ENV
  74. elif [[ ${{matrix.target}} == "meson_meson8b" ]]; then
  75. echo "MTARGET=arm_cortex-a5_vfpv4" >> $GITHUB_ENV
  76. elif [[ ${{matrix.target}} == "bcm53xx" ]]; then
  77. echo "MTARGET=arm_cortex-a9" >> $GITHUB_ENV
  78. elif [[ ${{matrix.target}} == "mvebu_cortexa9" ]]; then
  79. echo "MTARGET=arm_cortex-a9_vfpv3-d16" >> $GITHUB_ENV
  80. elif [[ ${{matrix.target}} == "ipq806x_generic" ]]; then
  81. echo "MTARGET=arm_cortex-a15_neon-vfpv4" >> $GITHUB_ENV
  82. elif [[ ${{matrix.target}} == "bcm27xx_bcm2708" ]]; then
  83. echo "MTARGET=arm_arm1176jzf-s_vfp" >> $GITHUB_ENV
  84. else
  85. echo "ARCH=linux/arm64" >> $GITHUB_ENV
  86. if [[ ${{matrix.target}} == "bcm27xx_bcm2711" ]]; then
  87. echo "MTARGET=aarch64_cortex-a72" >> $GITHUB_ENV
  88. elif [[ ${{matrix.target}} == rockchip* ]]; then
  89. echo "MTARGET=aarch64_generic" >> $GITHUB_ENV
  90. fi
  91. fi
  92. - name: Trigger Packages Update
  93. continue-on-error: true
  94. run: |
  95. status=$(curl -H "Authorization: token ${{ secrets.TOKEN_KIDDIN9 }} -s "https://api.github.com/repos/kiddin9/openwrt-packages/actions/runs" | jq -r '.workflow_runs[0].status')
  96. if [[ "$status" == "completed" ]]; then
  97. curl -X POST https://api.github.com/repos/kiddin9/openwrt-packages/dispatches \
  98. -H "Accept: application/vnd.github.everest-preview+json" \
  99. -H "Authorization: token ${{ secrets.TOKEN_KIDDIN9 }}" \
  100. --data '{"event_type": "update"}'
  101. fi
  102. - name: Initialization environment
  103. env:
  104. DEBIAN_FRONTEND: noninteractive
  105. run: |
  106. sudo -E apt-get -qq update
  107. sudo -E apt-get -qq install build-essential clang llvm flex g++ gawk gcc-multilib gettext \
  108. git libncurses5-dev libssl-dev python3-distutils python3-pyelftools python3-setuptools \
  109. libpython3-dev rsync unzip zlib1g-dev swig aria2 jq subversion qemu-utils ccache rename \
  110. libelf-dev device-tree-compiler libgnutls28-dev coccinelle libgmp3-dev libmpc-dev
  111. sudo -E apt-get -qq purge azure-cli ghc* zulu* firefox powershell openjdk* dotnet* google* mysql* php* android*
  112. sudo rm -rf /etc/apt/sources.list.d/* /usr/share/dotnet /usr/local/lib/android /opt/ghc
  113. sudo -E apt-get -qq autoremove --purge
  114. sudo -E apt-get -qq clean
  115. sudo timedatectl set-timezone "$TZ"
  116. git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com"
  117. git config --global user.name "github-actions[bot]"
  118. - name: Get current date
  119. id: date
  120. run: |
  121. echo "date=$(date +'%m/%d_%Y_%H/%M')" >> $GITHUB_ENV
  122. echo "date2=$(date +'%m/%d %Y')" >> $GITHUB_ENV
  123. VERSION="$(echo "${{github.event.action}}" | grep -Eo " [0-9.]+" | sed -e 's/ //')" || true
  124. [ "$VERSION" ] && echo "VERSION=$VERSION" >> $GITHUB_ENV || echo "VERSION=$(date +'%m.%d')" >> $GITHUB_ENV
  125. - name: Clone source code
  126. run: |
  127. REPO_BRANCH="$((curl -gs -H 'Content-Type: application/json' \
  128. -H "Authorization: Bearer ${{ secrets.TOKEN_KIDDIN9 }}" \
  129. -X POST -d '{ "query": "query {repository(owner: \"openwrt\", name: \"openwrt\") {refs(refPrefix: \"refs/tags/\", last: 4, orderBy: {field: TAG_COMMIT_DATE, direction: ASC}) {edges {node {name}}}}}"}' https://api.github.com/graphql) | jq -r '.data.repository.refs.edges[].node.name' | grep v23 | tail -n 1)"
  130. REPO_BRANCH="openwrt-23.05"
  131. #echo "CONFIG_VERSION_REPO=\"https://dl.openwrt.ai/`echo $REPO_BRANCH | cut -d . -f 1,2 | sed -e 's/^v//'`\"">>devices/common/.config
  132. echo "CONFIG_VERSION_REPO=\"https://dl.openwrt.ai/23.05\"">>devices/common/.config
  133. if [[ ! "${{ env.REPO_BRANCH }}" && "$REPO_URL" == "https://github.com/openwrt/openwrt" ]]; then
  134. git clone $REPO_URL -b $REPO_BRANCH openwrt
  135. elif [[ ! "${{ env.REPO_BRANCH }}" ]]; then
  136. git clone $REPO_URL openwrt
  137. else
  138. git clone $REPO_URL -b ${{ env.REPO_BRANCH }} openwrt
  139. echo "git clone $REPO_URL -b ${{ env.REPO_BRANCH }} openwrt"
  140. fi
  141. - name: Free up disk space
  142. env:
  143. DEBIAN_FRONTEND: noninteractive
  144. run: |
  145. sudo mkdir -p -m 777 /mnt/openwrt/dl /mnt/openwrt/staging_dir /mnt/openwrt/build_dir
  146. ln -sf /mnt/openwrt/dl openwrt/dl
  147. ln -sf /mnt/openwrt/staging_dir openwrt/staging_dir
  148. ln -sf /mnt/openwrt/build_dir openwrt/build_dir
  149. - name: Load custom configuration
  150. run: |
  151. function git_clone_path() {
  152. branch="$1" rurl="$2" localdir="gitemp" && shift 2
  153. git clone -b $branch --depth 1 --filter=blob:none --sparse $rurl $localdir
  154. if [ "$?" != 0 ]; then
  155. echo "error on $rurl"
  156. return 0
  157. fi
  158. cd $localdir
  159. git sparse-checkout init --cone
  160. git sparse-checkout set $@
  161. cp -rn $@ ../$(dirname "$@")/
  162. cd ..
  163. rm -rf gitemp
  164. }
  165. export -f git_clone_path
  166. cp -rf devices/common/. openwrt/
  167. cp -rf devices/${{matrix.target}}/. openwrt/
  168. cp -rf devices openwrt/
  169. cd openwrt
  170. chmod +x devices/common/$DIY_SH
  171. /bin/bash "devices/common/$DIY_SH"
  172. cp -f devices/common/$CONFIG_FILE .config
  173. if [ -f "devices/${{matrix.target}}/$CONFIG_FILE" ]; then
  174. echo >> .config
  175. cat devices/${{matrix.target}}/$CONFIG_FILE >> .config
  176. fi
  177. if [ -f "devices/${{matrix.target}}/$DIY_SH" ]; then
  178. chmod +x devices/${{matrix.target}}/$DIY_SH
  179. echo "/bin/bash devices/${{matrix.target}}/$DIY_SH"
  180. /bin/bash "devices/${{matrix.target}}/$DIY_SH"
  181. fi
  182. cp -Rf ./diy/* ./ || true
  183. - name: Apply patches
  184. run: |
  185. cd openwrt
  186. find "devices/common/patches" -type f ! -name 'china_mirrors.patch' -name '*.patch' ! -name '*.revert.patch' -print0 | sort -z | xargs -I % -t -0 -n 1 sh -c "cat '%' | patch -d './' -B --merge -p1 -E --forward"
  187. #git apply devices/common/patches/*.patch
  188. if [ -n "$(ls -A devices/${{matrix.target}}/patches 2>/dev/null)" ]; then
  189. if [ -n "$(ls -A devices/${{matrix.target}}/*.bin.patch 2>/dev/null)" ]; then
  190. git apply devices/${{matrix.target}}/patches/*.bin.patch
  191. fi
  192. find "devices/${{matrix.target}}/patches" -maxdepth 1 -type f -name '*.revert.patch' -print0 | sort -z | xargs -I % -t -0 -n 1 sh -c "cat '%' | patch -d './' -R -B --merge -p1 -E --forward"
  193. find "devices/${{matrix.target}}/patches" -maxdepth 1 -type f -name '*.patch' ! -name '*.revert.patch' ! -name '*.bin.patch' -print0 | sort -z | xargs -I % -t -0 -n 1 sh -c "cat '%' | patch -d './' -B --merge -p1 -E --forward"
  194. fi
  195. sed -i '$a \
  196. CONFIG_CPU_FREQ_GOV_POWERSAVE=y \
  197. CONFIG_CPU_FREQ_GOV_USERSPACE=y \
  198. CONFIG_CPU_FREQ_GOV_ONDEMAND=y \
  199. CONFIG_CPU_FREQ_GOV_CONSERVATIVE=y \
  200. CONFIG_CRYPTO_CHACHA20_NEON=y \
  201. CONFIG_CRYPTO_CHACHA20POLY1305=y \
  202. CONFIG_FAT_DEFAULT_IOCHARSET="utf8" \
  203. ' `find target/linux -path "target/linux/*/config-*"`
  204. - name: Defconfig
  205. run: |
  206. cd openwrt
  207. make defconfig
  208. if [[ ! "${{matrix.target}}" =~ (armsr_armv8|bcm27xx_*|rockchip_*|sunxi_*|x86_*|meson_meson8b) ]]; then
  209. sed -n '/# Wireless Drivers/,/# end of Wireless Drivers/p' .config | sed -e 's/=m/=n/' >>.config
  210. sed -i "s/\(kmod-qca.*\)=m/\1=n/" .config
  211. make defconfig
  212. fi
  213. cat .config
  214. - name: Download package
  215. id: package
  216. run: |
  217. cd openwrt
  218. make download -j$(($(nproc)+1)) &
  219. sleep 5
  220. - name: Cache
  221. uses: stupidloud/cachewrtbuild@main
  222. with:
  223. ccache: 'true'
  224. mixkey: ${{ matrix.target }}
  225. clean: ${{ contains(github.event.action, 'nocache') }}
  226. prefix: ${{ github.workspace }}/openwrt
  227. - name: Check space usage
  228. run: |
  229. shopt -s extglob
  230. cd openwrt
  231. if [[ -f staging_dir/*${{ env.MTARGET }}*/bin ]]; then
  232. rm -rf staging_dir/!(*${{ env.MTARGET }}*|host|hostpkg) build_dir/!(*${{ env.MTARGET }}*|host|hostpkg)
  233. fi
  234. df -hT
  235. - name: SSH connection to Actions
  236. uses: kiddin9/debugger-action@master
  237. if: contains(github.event.action, 'ssh')
  238. - name: Compile the firmware
  239. id: compile
  240. run: |
  241. shopt -s extglob
  242. cd openwrt
  243. echo -e "$(($(nproc)+1)) thread compile"
  244. make -j$(($(nproc)+1)) || make V=s &>build.log || (tail -50 build.log; curl -k --data chat_id="${{ env.TELEGRAM_CHAT_ID }}" --data "text=❌ OpenWrt ${{ env.VERSION }} ${{matrix.target}} 编译失败 😂" "https://api.telegram.org/bot${{ env.TELEGRAM_TOKEN }}/sendMessage";df -hT;exit 1)
  245. sed -i "s/# CONFIG_IB is not set/CONFIG_IB=y/" .config
  246. rm -rf staging_dir/toolchain-*/bin/*openwrt-linux-musl-lto-dump
  247. rm -rf staging_dir/toolchain-*/initial
  248. df -hT
  249. - name: Organize files
  250. id: organize
  251. continue-on-error: true
  252. run: |
  253. shopt -s extglob
  254. mkdir -p firmware/${{matrix.target}}
  255. cp -rf openwrt/bin/targets/*/*/*{combined,sysupgrade}* ./firmware/${{matrix.target}}/ || true
  256. cd openwrt/bin/targets/*/*/
  257. cp $GITHUB_WORKSPACE/openwrt/.config ${{matrix.target}}.config || true
  258. cp $GITHUB_WORKSPACE/openwrt/build_dir/target-*/linux-*/linux-*/.config ${{matrix.target}}_kernel.config || true
  259. cd -
  260. rename -v "s/openwrt-/${{ env.VERSION }}-openwrt-/" ./firmware/*/* || true
  261. Emoji=("🎉" "🤞" "✨" "🎁" "🎈" "🎄" "🎨" "💋" "🍓" "🍕" "🍉" "💐" "🌴" "🚀" "🛸" "🗽" "⛅" "🌈" "🔥" "⛄" "🐶" "🏅" "🦄" "🐤")
  262. echo "EMOJI=${Emoji[$[$RANDOM % ${#Emoji[@]}]]}" >> $GITHUB_ENV
  263. if [ ${{matrix.target}} == "x86_64" ]; then
  264. echo "DOCKERTAG=${{ secrets.DOCKER_ID }}/openwrt-nginx:latest" >> $GITHUB_ENV
  265. echo "NOTICE=请分配不少于1G的存储容量" >> $GITHUB_ENV
  266. fi
  267. - name: Deploy imagebuilder to server
  268. uses: easingthemes/ssh-deploy@main
  269. continue-on-error: true
  270. if: env.SSH_PRIVATE_KEY && ! contains(github.event.action, 'noser')
  271. with:
  272. SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
  273. ARGS: "-avzr"
  274. SOURCE: openwrt/bin/targets
  275. REMOTE_HOST: ${{ secrets.SERVER_HOST }}
  276. REMOTE_PORT: ${{ secrets.SERVER_PORT }}
  277. REMOTE_USER: root
  278. TARGET: "/www/wwwroot/dl.openwrt.ai/releases/tmp/"
  279. - name: Upload firmware for artifact
  280. uses: actions/upload-artifact@main
  281. if: env.UPLOAD_FIRMWARE_FOR_ARTIFACT == 'true'
  282. with:
  283. name: ${{ env.VERSION }}_${{matrix.target}}
  284. path: |
  285. openwrt/bin/targets/
  286. - name: Create release
  287. id: create_release
  288. if: env.REPO_TOKEN && env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true'
  289. continue-on-error: true
  290. run: |
  291. echo -e "墙内加速下载 🚀:\n" >> release.txt
  292. echo -e "[腾讯云] (https://dl.openwrt.ai/firmware/${{matrix.target}}/ ☁)\n" >> release.txt
  293. [ ${{ env.WETRANS }} ] && echo -e "[WeTransfer] (${{ env.WETRANS }} 🗽)\n" >> release.txt
  294. [ ${{ env.COWURL }} ] && echo -e "[奶牛上传] (${{ env.COWURL }} 🐮)\n" >> release.txt
  295. [ ${{ env.NOTICE }} ] && echo -e "${{ env.NOTICE }}" >> release.txt || true
  296. - name: Upload firmware for release
  297. uses: softprops/action-gh-release@master
  298. continue-on-error: true
  299. if: env.REPO_TOKEN && env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true'
  300. env:
  301. GITHUB_TOKEN: ${{ secrets.TOKEN_KIDDIN9 }}
  302. with:
  303. files: "${{ env.FIRMWARE }}/*"
  304. name: ${{ env.date2 }} ${{matrix.target}} ${{ env.EMOJI }}
  305. tag_name: ${{ env.date }}_${{matrix.target}}
  306. body_path: release.txt
  307. - name: WeChat notification
  308. continue-on-error: true
  309. if: env.SCKEY
  310. run: |
  311. # [ steps.compile.outputs.status == 'success' ] && curl https://sctapi.ftqq.com/${{ secrets.SCKEY }}.send?text=🎉OpenWrt_${{ env.VERSION }}_${{matrix.target}}编译完成😋|| curl https://sctapi.ftqq.com/${{ secrets.SCKEY }}.send?text=❌OpenWrt_${{ env.VERSION }}_${{matrix.target}}编译失败😂
  312. - name: Telegram notification
  313. if: env.TELEGRAM_TOKEN && ! contains(github.event.action, 'notg')
  314. continue-on-error: true
  315. run: |
  316. curl -k --data chat_id="${{ env.TELEGRAM_CHAT_ID }}" --data "text=🎉 OpenWrt ${{ env.VERSION }} ${{matrix.target}} 编译成功 😋 https://dl.openwrt.ai/firmware/${{matrix.target}}/ ${{ env.COWURL }} ${{ env.WETRANS }} 🚀" "https://api.telegram.org/bot${{ env.TELEGRAM_TOKEN }}/sendMessage"
  317. - name: Delete workflow runs
  318. uses: GitRML/delete-workflow-runs@main
  319. continue-on-error: true
  320. with:
  321. retain_days: 100
  322. keep_minimum_runs: 0
  323. - name: Remove old Releases
  324. uses: dev-drprasad/delete-older-releases@master
  325. continue-on-error: true
  326. if: env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true' && !cancelled()
  327. with:
  328. keep_latest: 15
  329. delete_tags: true
  330. env:
  331. GITHUB_TOKEN: ${{ secrets.TOKEN_KIDDIN9 }}