Openwrt-AutoBuild.yml 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  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.REPO_TOKEN }}
  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-20.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: cancel running workflows
  36. uses: styfle/cancel-workflow-action@main
  37. if: contains(github.event.action, 'cw')
  38. with:
  39. workflow_id: 4439867
  40. access_token: ${{ github.token }}
  41. - name: Load Settings.ini
  42. run: |
  43. source "${GITHUB_WORKSPACE}/devices/common/settings.ini"
  44. if [ -f "devices/${{matrix.target}}/settings.ini" ]; then
  45. source "${GITHUB_WORKSPACE}/devices/${{matrix.target}}/settings.ini"
  46. fi
  47. echo "REPO_URL=${REPO_URL}" >> $GITHUB_ENV
  48. echo "REPO_BRANCH=${REPO_BRANCH}" >> $GITHUB_ENV
  49. echo "CONFIG_FILE=${CONFIG_FILE}" >> $GITHUB_ENV
  50. echo "DIY_SH=${DIY_SH}" >> $GITHUB_ENV
  51. echo "FREE_UP_DISK=${FREE_UP_DISK}" >> $GITHUB_ENV
  52. echo "UPLOAD_BIN_DIR_FOR_ARTIFACT=${UPLOAD_BIN_DIR_FOR_ARTIFACT}" >> $GITHUB_ENV
  53. echo "UPLOAD_FIRMWARE_FOR_ARTIFACT=${UPLOAD_FIRMWARE_FOR_ARTIFACT}" >> $GITHUB_ENV
  54. echo "UPLOAD_FIRMWARE_FOR_RELEASE=${UPLOAD_FIRMWARE_FOR_RELEASE}" >> $GITHUB_ENV
  55. echo "UPLOAD_FIRMWARE_TO_COWTRANSFER=${UPLOAD_FIRMWARE_TO_COWTRANSFER}" >> $GITHUB_ENV
  56. echo "UPLOAD_FIRMWARE_TO_WETRANSFER=${UPLOAD_FIRMWARE_TO_WETRANSFER}" >> $GITHUB_ENV
  57. if [ ${{matrix.target}} == "x86_64" ]; then
  58. echo "ARCH=linux/amd64" >> $GITHUB_ENV
  59. echo "MTARGET=x86_64" >> $GITHUB_ENV
  60. elif [[ ${{matrix.target}} =~ (Rpi-4B|nanopi-r2s|nanopi-r4s) ]]; then
  61. echo "ARCH=linux/arm64" >> $GITHUB_ENV
  62. fi
  63. if [ ${{matrix.target}} == "Rpi-4B" ]; then
  64. echo "MTARGET=aarch64_cortex-a72" >> $GITHUB_ENV
  65. elif [ ${{matrix.target}} == "nanopi-r2s" ]; then
  66. echo "MTARGET=aarch64_generic" >> $GITHUB_ENV
  67. fi
  68. - name: Trigger Packages Update
  69. run: |
  70. gitdate=$(curl -s "https://api.github.com/repos/kiddin9/openwrt-packages/actions/runs" | jq -r '.workflow_runs[0].created_at')
  71. gitdate=$(date -d "$gitdate" +%s)
  72. now=$(date -d "$(date '+%Y-%m-%d %H:%M:%S')" +%s)
  73. if [[ $(expr $gitdate + 300) < $now ]]; then
  74. curl -X POST https://api.github.com/repos/kiddin9/openwrt-packages/dispatches \
  75. -H "Accept: application/vnd.github.everest-preview+json" \
  76. -H "Authorization: token ${{ secrets.REPO_TOKEN }}" \
  77. --data '{"event_type": "update"}'
  78. fi
  79. - name: Initialization environment
  80. env:
  81. DEBIAN_FRONTEND: noninteractive
  82. run: |
  83. ( sudo -E apt-get -qq update
  84. sudo -E apt-get -qq install build-essential asciidoc binutils bzip2 gawk gettext git libncurses5-dev patch python3 python2.7 unzip zlib1g-dev lib32gcc-s1 libc6-dev-i386 subversion flex uglifyjs gcc-multilib g++-multilib p7zip p7zip-full msmtp libssl-dev texinfo libglib2.0-dev xmlto qemu-utils upx-ucl libelf-dev autoconf automake libtool autopoint device-tree-compiler ccache xsltproc rename antlr3 gperf wget curl swig rsync
  85. sudo -E apt-get -qq purge azure-cli ghc* zulu* hhvm llvm* firefox powershell openjdk* dotnet* google* mysql* php* android*
  86. sudo rm -rf /etc/apt/sources.list.d/* /usr/share/dotnet /usr/local/lib/android /opt/ghc
  87. sudo -E apt-get -qq autoremove --purge
  88. sudo -E apt-get -qq clean ) &
  89. sudo timedatectl set-timezone "$TZ"
  90. - name: Get current date
  91. id: date
  92. run: |
  93. echo "date=$(date +'%m/%d_%Y_%H/%M')" >> $GITHUB_ENV
  94. echo "date2=$(date +'%m/%d %Y')" >> $GITHUB_ENV
  95. VERSION="$(echo "${{github.event.action}}" | grep -Eo " [0-9.]+" | sed -e 's/ //')" || true
  96. [ "$VERSION" ] && echo "VERSION=$VERSION" >> $GITHUB_ENV || echo "VERSION=$(date +'%m.%d')" >> $GITHUB_ENV
  97. - name: Clone source code
  98. run: |
  99. [ "$REPO_BRANCH" ] ||
  100. REPO_BRANCH="$((curl -gs -H 'Content-Type: application/json' \
  101. -H "Authorization: Bearer ${{ secrets.REPO_TOKEN }}" \
  102. -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 v21 | tail -n 1 | sed -e 's/v//')"
  103. git clone $REPO_URL -b v$REPO_BRANCH openwrt
  104. if [[ "${{ contains(github.event.action, 'sdk') }}" == "true" ]]; then
  105. cd openwrt
  106. if [[ ${{matrix.target}} == "x86_64" ]]; then
  107. curl -fL -m 60 -o sdk.tar.xz https://downloads.openwrt.org/releases/$REPO_BRANCH/targets/x86/64/openwrt-sdk-$REPO_BRANCH-x86-64_gcc-8.4.0_musl.Linux-x86_64.tar.xz || curl -fL -m 60 -o sdk.tar.xz https://openwrt.tetaneutral.net/releases/21.02-SNAPSHOT/targets/x86/64/openwrt-sdk-21.02-SNAPSHOT-x86-64_gcc-8.4.0_musl.Linux-x86_64.tar.xz
  108. elif [[ ${{matrix.target}} == nanopi* ]]; then
  109. curl -fL -m 60 -o sdk.tar.xz https://downloads.openwrt.org/releases/$REPO_BRANCH/targets/rockchip/armv8/openwrt-sdk-$REPO_BRANCH-rockchip-armv8_gcc-8.4.0_musl.Linux-x86_64.tar.xz || curl -fL -m 60 -o sdk.tar.xz https://openwrt.tetaneutral.net/releases/21.02-SNAPSHOT/targets/rockchip/armv8/openwrt-sdk-21.02-SNAPSHOT-rockchip-armv8_gcc-8.4.0_musl.Linux-x86_64.tar.xz
  110. elif [[ ${{matrix.target}} =~ "Rpi-4B" ]]; then
  111. curl -fL -m 60 -o sdk.tar.xz https://downloads.openwrt.org/releases/$REPO_BRANCH/targets/bcm27xx/bcm2711/openwrt-sdk-$REPO_BRANCH-bcm27xx-bcm2711_gcc-8.4.0_musl.Linux-x86_64.tar.xz || curl -fL -m 60 -o sdk.tar.xz https://openwrt.tetaneutral.net/releases/21.02-SNAPSHOT/targets/bcm27xx/bcm2711/openwrt-sdk-21.02-SNAPSHOT-bcm27xx-bcm2711_gcc-8.4.0_musl.Linux-x86_64.tar.xz
  112. fi
  113. fi
  114. echo "REPO_BRANCH=$REPO_BRANCH" >> $GITHUB_ENV
  115. - name: Free up disk space
  116. if: env.FREE_UP_DISK == 'true'
  117. env:
  118. DEBIAN_FRONTEND: noninteractive
  119. run: |
  120. sudo mkdir -p -m 777 /mnt/openwrt/dl /mnt/openwrt/staging_dir /mnt/openwrt/build_dir/hostpkg openwrt/build_dir
  121. ln -sf /mnt/openwrt/dl openwrt/dl
  122. ln -sf /mnt/openwrt/staging_dir openwrt/staging_dir
  123. ln -sf /mnt/openwrt/build_dir/hostpkg openwrt/build_dir/hostpkg
  124. - name: Load custom configuration
  125. run: |
  126. cp -rf devices/common/. openwrt/
  127. cp -rf devices/${{matrix.target}}/. openwrt/
  128. cp -rf devices openwrt/
  129. cd openwrt
  130. chmod +x devices/common/$DIY_SH
  131. /bin/bash "devices/common/$DIY_SH"
  132. if [ -f "devices/${{matrix.target}}/$DIY_SH" ]; then
  133. chmod +x devices/${{matrix.target}}/$DIY_SH
  134. /bin/bash "devices/${{matrix.target}}/$DIY_SH"
  135. fi
  136. cp -Rf ./diy/* ./ || true
  137. if [ -f "devices/${{matrix.target}}/default-settings" ]; then
  138. echo >> package/*/*/my-default-settings/files/uci.defaults
  139. cat devices/${{matrix.target}}/default-settings >> package/*/*/my-default-settings/files/uci.defaults
  140. fi
  141. cp -f devices/common/$CONFIG_FILE .config
  142. if [ -f "devices/${{matrix.target}}/$CONFIG_FILE" ]; then
  143. echo >> .config
  144. cat devices/${{matrix.target}}/$CONFIG_FILE >> .config
  145. fi
  146. - name: Apply patches
  147. run: |
  148. cd openwrt
  149. find "devices/common/patches" -type f ! -path 'devices/common/patches/china_mirrors.patch' -name '*.patch' -print0 | sort -z | xargs -I % -t -0 -n 1 sh -c "cat '%' | patch -d './' -p1 -E --forward --no-backup-if-mismatch"
  150. if [ -n "$(ls -A "devices/${{matrix.target}}/patches" 2>/dev/null)" ]; then
  151. find "devices/${{matrix.target}}/patches" -type f -name '*.patch' ! -name '*.revert.patch' -print0 | sort -z | xargs -I % -t -0 -n 1 sh -c "cat '%' | patch -d './' -p1 -E --forward --no-backup-if-mismatch"
  152. fi
  153. - name: Default PPPOE Setting
  154. if: env.PPPOE_USERNAME && env.PPPOE_PASSWD
  155. run: |
  156. sed -i '$i uci set network.wan.username=${{ env.PPPOE_USERNAME }}' openwrt/package/*/*/my-default-settings/files/uci.defaults
  157. sed -i '$i uci set network.wan.password=${{ env.PPPOE_PASSWD }}' openwrt/package/*/*/my-default-settings/files/uci.defaults
  158. sed -i '$i uci commit network' openwrt/package/*/*/my-default-settings/files/uci.defaults
  159. - name: SSH connection to Actions
  160. uses: kiddin9/debugger-action@master
  161. if: contains(github.event.action, 'ssh')
  162. - name: Download package
  163. id: package
  164. run: |
  165. cd openwrt
  166. make defconfig
  167. for i in $(make --file=preset_pkg.mk presetpkg); do
  168. sed -i "\$a CONFIG_PACKAGE_$i=y" .config
  169. done
  170. make defconfig
  171. make download -j$(($(nproc)+1)) &
  172. - name: Cache
  173. uses: klever1988/cachewrtbuild@main
  174. with:
  175. ccache: 'true'
  176. clean: ${{ contains(github.event.action, 'nocache') }}
  177. prefix: ${{ github.workspace }}/openwrt
  178. - name: Compile the firmware
  179. id: compile
  180. run: |
  181. cd openwrt
  182. echo -e "$(($(nproc)+1)) thread compile"
  183. make -j$(($(nproc)+1)) || make -j1 V=s
  184. echo "::set-output name=status::success"
  185. mv -f .config ${{matrix.target}}.config
  186. if [ "${{matrix.target}}" == "nanopi-r2s" ]; then
  187. echo "开始编译R2C"
  188. cp -f devices/common/$CONFIG_FILE .config
  189. echo >> .config
  190. cat devices/nanopi-r2c/$CONFIG_FILE >> .config
  191. make defconfig
  192. make -j$(($(nproc)+1)) || make -j1 V=s || {
  193. echo "R2C编译失败";
  194. exit 1;
  195. }
  196. mv -f .config nanopi-r2c.config
  197. echo "开始编译R4S"
  198. cp -f devices/common/$CONFIG_FILE .config
  199. echo >> .config
  200. cat devices/nanopi-r4s/$CONFIG_FILE >> .config
  201. make defconfig
  202. make -j$(($(nproc)+1)) || make -j1 V=s || {
  203. echo "R4S编译失败";
  204. exit 1;
  205. }
  206. mv -f .config nanopi-r4s.config
  207. fi
  208. - name: Check space usage
  209. run: df -hT
  210. - name: Organize files
  211. id: organize
  212. run: |
  213. shopt -s extglob
  214. mkdir -p firmware/${{matrix.target}} kmods
  215. if [[ ${{matrix.target}} == "nanopi-r4s" || ${{matrix.target}} == "nanopi-r2c" ]]; then
  216. rm -rf openwrt/bin/targets/*/*/!(*.gz)
  217. fi
  218. if [ -f openwrt/bin/targets/*/*/*r2s*sysupgrade* ]; then
  219. mkdir firmware/nanopi-r4s
  220. mv -f openwrt/nanopi-r4s.config firmware/nanopi-r4s/ || true
  221. cp -rf openwrt/bin/targets/*/*/*r4s*sysupgrade* ./firmware/nanopi-r4s/ || true
  222. mkdir firmware/nanopi-r2c
  223. mv -f openwrt/nanopi-r2c.config firmware/nanopi-r2c/ || true
  224. cp -rf openwrt/bin/targets/*/*/*r2c*sysupgrade* ./firmware/nanopi-r2c/ || true
  225. cp -rf openwrt/bin/targets/*/*/*{combined,r2s*sysupgrade,rpi-4*sysupgrade}* ./firmware/${{matrix.target}}/ || true
  226. else
  227. cp -rf openwrt/bin/targets/*/*/*{combined,sysupgrade}* ./firmware/${{matrix.target}}/ || true
  228. fi
  229. cp openwrt/${{matrix.target}}.config ./firmware/${{matrix.target}}/${{matrix.target}}.config || true
  230. cp openwrt/build_dir/target-*/linux-*/linux-*/.config ./firmware/${{matrix.target}}/${{matrix.target}}_kernel.config
  231. kernel_v="$(cat openwrt/include/kernel-5.10 | grep LINUX_KERNEL_HASH-5.10* | cut -f 2 -d - | cut -f 1 -d ' ')"
  232. cp -rf openwrt/bin/targets/*/*/packages ./kmods/$kernel_v || true
  233. rm -rf openwrt/bin/targets/*/*/packages/*.ipk
  234. cp -rf openwrt/bin/targets/*/*/*{combined,r2s*sysupgrade,rpi-4*sysupgrade}* ./firmware/${{matrix.target}}/ || true
  235. rename -v "s/openwrt-/${{ env.VERSION }}-openwrt-/" ./firmware/*/* || true
  236. rename -v "s/friendlyarm_//" ./firmware/*/*gz || true
  237. for i in $(ls -d firmware/*/); do
  238. echo "${{ env.VERSION }}.$(date +'%Y')" > $i/version.txt
  239. md5=$((md5sum $i/*squashfs-sysupgrade* || md5sum $i/*squashfs-combined-efi*) | awk '{print $1}') 2>/dev/null
  240. echo $md5 >> $i/version.txt
  241. echo v$REPO_BRANCH >> $i/version.txt
  242. done
  243. Emoji=("🎉" "🤞" "✨" "🎁" "🎈" "🎄" "🎨" "💋" "🍓" "🍕" "🍉" "💐" "🌴" "🚀" "🛸" "🗽" "⛅" "🌈" "🔥" "⛄" "🐶" "🏅" "🦄" "🐤")
  244. echo "EMOJI=${Emoji[$[$RANDOM % ${#Emoji[@]}]]}" >> $GITHUB_ENV
  245. if [ ${{matrix.target}} == "x86_64" ]; then
  246. echo "DOCKERTAG=${{ secrets.DOCKER_ID }}/openwrt-nginx:latest" >> $GITHUB_ENV
  247. echo "NOTICE=请分配不少于1G的存储容量" >> $GITHUB_ENV
  248. fi
  249. - name: Deploy firmware to server
  250. uses: easingthemes/ssh-deploy@main
  251. if: env.SSH_PRIVATE_KEY && contains(github.event.action, 'ser')
  252. with:
  253. SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
  254. ARGS: "-avzr --exclude="
  255. SOURCE: firmware/
  256. REMOTE_HOST: op.supes.top
  257. REMOTE_USER: root
  258. TARGET: "/www/wwwroot/op.supes.top/firmware/"
  259. - name: Deploy kmods to server
  260. uses: easingthemes/ssh-deploy@main
  261. if: env.SSH_PRIVATE_KEY && ! contains(github.event.action, 'noser') && env.MTARGET
  262. with:
  263. SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
  264. ARGS: "-avzr"
  265. SOURCE: kmods/
  266. REMOTE_HOST: op.supes.top
  267. REMOTE_USER: root
  268. TARGET: "/www/wwwroot/op.supes.top/packages/${{ env.MTARGET }}/kmods/"
  269. - name: Deploy imagebuilder to server
  270. uses: easingthemes/ssh-deploy@main
  271. if: env.SSH_PRIVATE_KEY && ! contains(github.event.action, 'noser')
  272. with:
  273. SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
  274. ARGS: "-avzr"
  275. SOURCE: openwrt/bin/targets
  276. REMOTE_HOST: op.supes.top
  277. REMOTE_USER: root
  278. TARGET: "/www/wwwroot/op.supes.top/releases/${{ env.REPO_BRANCH }}/"
  279. - name: Upload firmware for artifact
  280. uses: actions/upload-artifact@main
  281. continue-on-error: true
  282. if: env.UPLOAD_FIRMWARE_FOR_ARTIFACT == 'true'
  283. with:
  284. name: ${{ env.VERSION }} ${{matrix.target}}
  285. path: |
  286. ./firmware/
  287. openwrt/bin/targets/*/
  288. - name: Upload firmware to cowtransfer
  289. if: env.UPLOAD_FIRMWARE_TO_COWTRANSFER == 'true'
  290. continue-on-error: true
  291. run: |
  292. curl -fsSL git.io/file-transfer | sh
  293. cowurl=$(./transfer cow --block 2621440 -s --no-progress ${FIRMWARE})
  294. cowurl=$(echo $cowurl | grep -o -E "https[^ ]*")
  295. echo "COWURL=$cowurl" >> $GITHUB_ENV
  296. echo "Download Link: ${{ env.EMOJI }} $cowurl ${{ env.EMOJI }} 🚀"
  297. - name: Upload firmware to WeTransfer
  298. if: env.UPLOAD_FIRMWARE_TO_WETRANSFER == 'true' && ! contains(github.event.action, 'noup')
  299. continue-on-error: true
  300. run: |
  301. curl -fsSL git.io/file-transfer | sh
  302. wetrans=$(./transfer wet -s -p 16 --no-progress ${FIRMWARE})
  303. wetrans=$(echo $wetrans | grep -o -E "https[^ ]*")
  304. echo "WETRANS=$wetrans" >> $GITHUB_ENV
  305. echo "Download Link: ${{ env.EMOJI }} $wetrans ${{ env.EMOJI }} 🚀"
  306. - name: Create release
  307. id: create_release
  308. if: env.REPO_TOKEN && env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true'
  309. continue-on-error: true
  310. run: |
  311. echo -e "墙内加速下载 🚀:\n" >> release.txt
  312. echo -e "[腾讯云] (https://op.supes.top/firmware/${{matrix.target}}/ ☁)\n" >> release.txt
  313. [ ${{ env.WETRANS }} ] && echo -e "[WeTransfer] (${{ env.WETRANS }} 🗽)\n" >> release.txt
  314. [ ${{ env.COWURL }} ] && echo -e "[奶牛上传] (${{ env.COWURL }} 🐮)\n" >> release.txt
  315. [ ${{ env.NOTICE }} ] && echo -e "${{ env.NOTICE }}" >> release.txt || true
  316. - name: Upload firmware for release
  317. uses: softprops/action-gh-release@master
  318. continue-on-error: true
  319. if: env.REPO_TOKEN && env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true'
  320. env:
  321. GITHUB_TOKEN: ${{ secrets.REPO_TOKEN }}
  322. with:
  323. files: "${{ env.FIRMWARE }}/*"
  324. name: ${{ env.date2 }} ${{matrix.target}} ${{ env.EMOJI }}
  325. tag_name: ${{ env.date }}_${{matrix.target}}
  326. body_path: release.txt
  327. - name: Set Up Docker Buildx
  328. uses: docker/setup-buildx-action@master
  329. if: env.DOCKER_ID && env.DOCKER_PASSWD
  330. - name: Login To DockerHub
  331. uses: docker/login-action@master
  332. if: env.DOCKER_ID && env.DOCKER_PASSWD
  333. with:
  334. username: ${{ secrets.DOCKER_ID }}
  335. password: ${{ secrets.DOCKER_PASSWD }}
  336. - name: Build and push docker image
  337. uses: docker/build-push-action@master
  338. continue-on-error: true
  339. if: env.DOCKER_ID && env.DOCKER_PASSWD && ! contains(github.event.action, 'noser')
  340. with:
  341. platforms: ${{ env.ARCH }}
  342. file: Dockerfile
  343. context: .
  344. push: true
  345. tags: |
  346. ${{ secrets.DOCKER_ID }}/openwrt-nginx:${{ matrix.target }}
  347. ${{ env.DOCKERTAG }}
  348. - name: WeChat notification
  349. continue-on-error: true
  350. if: env.SCKEY
  351. run: |
  352. # [ 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}}编译失败😂
  353. - name: Telegram notification
  354. if: env.TELEGRAM_TOKEN && ! contains(github.event.action, 'notg')
  355. continue-on-error: true
  356. run: |
  357. [ steps.compile.outputs.status == 'success' ] && curl -k --data chat_id="${{ secrets.TELEGRAM_CHAT_ID }}" --data "text=🎉 OpenWrt ${{ env.VERSION }} ${{matrix.target}} 编译成功 😋 https://op.supes.top/firmware/${{matrix.target}}/ ${{ env.COWURL }} ${{ env.WETRANS }} 🚀" "https://api.telegram.org/bot${{ secrets.TELEGRAM_TOKEN }}/sendMessage" || curl -k --data chat_id="${{ secrets.TELEGRAM_TO }}" --data "text=❌ OpenWrt ${{ env.VERSION }} ${{matrix.target}} 编译失败 😂" "https://api.telegram.org/bot${{ secrets.TELEGRAM_TOKEN }}/sendMessage"
  358. - name: Delete workflow runs
  359. uses: GitRML/delete-workflow-runs@main
  360. continue-on-error: true
  361. with:
  362. retain_days: 10
  363. keep_minimum_runs: 0
  364. - name: Remove old Releases
  365. uses: dev-drprasad/delete-older-releases@master
  366. continue-on-error: true
  367. if: env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true' && !cancelled()
  368. with:
  369. keep_latest: 15
  370. delete_tags: true
  371. env:
  372. GITHUB_TOKEN: ${{ secrets.REPO_TOKEN }}