Openwrt-AutoBuild.yml 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379
  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: 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: cancel running workflows
  40. uses: styfle/cancel-workflow-action@main
  41. if: contains(github.event.action, 'cw')
  42. with:
  43. workflow_id: 4439867
  44. access_token: ${{ github.token }}
  45. - name: Load Settings.ini
  46. run: |
  47. echo ${{matrix.target}}
  48. source "${GITHUB_WORKSPACE}/devices/common/settings.ini"
  49. if [ -f "devices/${{matrix.target}}/settings.ini" ]; then
  50. source "${GITHUB_WORKSPACE}/devices/${{matrix.target}}/settings.ini"
  51. fi
  52. echo "REPO_URL=${REPO_URL}" >> $GITHUB_ENV
  53. echo "REPO_BRANCH=${REPO_BRANCH}" >> $GITHUB_ENV
  54. echo "CONFIG_FILE=${CONFIG_FILE}" >> $GITHUB_ENV
  55. echo "DIY_SH=${DIY_SH}" >> $GITHUB_ENV
  56. echo "FREE_UP_DISK=${FREE_UP_DISK}" >> $GITHUB_ENV
  57. echo "UPLOAD_BIN_DIR_FOR_ARTIFACT=${UPLOAD_BIN_DIR_FOR_ARTIFACT}" >> $GITHUB_ENV
  58. echo "UPLOAD_FIRMWARE_FOR_ARTIFACT=${UPLOAD_FIRMWARE_FOR_ARTIFACT}" >> $GITHUB_ENV
  59. echo "UPLOAD_FIRMWARE_FOR_RELEASE=${UPLOAD_FIRMWARE_FOR_RELEASE}" >> $GITHUB_ENV
  60. echo "UPLOAD_FIRMWARE_TO_COWTRANSFER=${UPLOAD_FIRMWARE_TO_COWTRANSFER}" >> $GITHUB_ENV
  61. echo "UPLOAD_FIRMWARE_TO_WETRANSFER=${UPLOAD_FIRMWARE_TO_WETRANSFER}" >> $GITHUB_ENV
  62. if [ ${{matrix.target}} == "x86_64" ]; then
  63. echo "ARCH=linux/amd64" >> $GITHUB_ENV
  64. echo "MTARGET=x86_64" >> $GITHUB_ENV
  65. elif [[ ${{matrix.target}} =~ (armvirt_64|ipq807x|mediatek_mt7622|bcm27xx_bcm2710|ipq60xx_generic|bcm4908_generic|sunxi_cortexa53) ]]; then
  66. echo "MTARGET=aarch64_cortex-a53" >> $GITHUB_ENV
  67. elif [[ ${{matrix.target}} =~ (ramips_mt7621|ramips_mt7620|ramips_mt76x8) ]]; then
  68. echo "MTARGET=mipsel_24kc" >> $GITHUB_ENV
  69. elif [[ ${{matrix.target}} =~ (ipq40xx_generic|bcm27xx_bcm2709|sunxi_cortexa7) ]]; then
  70. echo "MTARGET=arm_cortex-a7_neon-vfpv4" >> $GITHUB_ENV
  71. elif [[ ${{matrix.target}} == "at91_sama5" ]]; then
  72. echo "MTARGET=arm_cortex-a5_vfpv4" >> $GITHUB_ENV
  73. elif [[ ${{matrix.target}} == "bcm53xx" ]]; then
  74. echo "MTARGET=arm_cortex-a9" >> $GITHUB_ENV
  75. elif [[ ${{matrix.target}} == "mvebu_cortexa9" ]]; then
  76. echo "MTARGET=arm_cortex-a9_vfpv3-d16" >> $GITHUB_ENV
  77. elif [[ ${{matrix.target}} == "ipq806x_generic" ]]; then
  78. echo "MTARGET=arm_cortex-a15_neon-vfpv4" >> $GITHUB_ENV
  79. elif [[ ${{matrix.target}} == "bcm27xx_bcm2708" ]]; then
  80. echo "MTARGET=arm_arm1176jzf-s_vfp" >> $GITHUB_ENV
  81. else
  82. echo "ARCH=linux/arm64" >> $GITHUB_ENV
  83. if [[ ${{matrix.target}} == "bcm27xx_bcm2711" ]]; then
  84. echo "MTARGET=aarch64_cortex-a72" >> $GITHUB_ENV
  85. elif [[ ${{matrix.target}} == "rockchip_armv8" ]]; then
  86. echo "MTARGET=aarch64_generic" >> $GITHUB_ENV
  87. fi
  88. fi
  89. - name: Trigger Packages Update
  90. run: |
  91. gitdate=$(curl -s "https://api.github.com/repos/kiddin9/openwrt-packages/actions/runs" | jq -r '.workflow_runs[0].created_at')
  92. gitdate=$(date -d "$gitdate" +%s)
  93. now=$(date -d "$(date)" +%s)
  94. if [[ $(expr $gitdate + 300) < $now ]]; then
  95. curl -X POST https://api.github.com/repos/kiddin9/openwrt-packages/dispatches \
  96. -H "Accept: application/vnd.github.everest-preview+json" \
  97. -H "Authorization: token ${{ secrets.REPO_TOKEN }}" \
  98. --data '{"event_type": "update"}'
  99. fi
  100. - name: Initialization environment
  101. env:
  102. DEBIAN_FRONTEND: noninteractive
  103. run: |
  104. ( sudo -E apt-get -qq update
  105. 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 libpython3-dev
  106. sudo -E apt-get -qq purge azure-cli ghc* zulu* hhvm llvm* firefox powershell openjdk* dotnet* google* mysql* php* android*
  107. sudo rm -rf /etc/apt/sources.list.d/* /usr/share/dotnet /usr/local/lib/android /opt/ghc
  108. sudo -E apt-get -qq autoremove --purge
  109. sudo -E apt-get -qq clean ) &
  110. sudo timedatectl set-timezone "$TZ"
  111. sudo mkdir -p /workdir
  112. sudo chown $USER:$GROUPS /workdir
  113. - name: Get current date
  114. id: date
  115. run: |
  116. echo "date=$(date +'%m/%d_%Y_%H/%M')" >> $GITHUB_ENV
  117. echo "date2=$(date +'%m/%d %Y')" >> $GITHUB_ENV
  118. VERSION="$(echo "${{github.event.action}}" | grep -Eo " [0-9.]+" | sed -e 's/ //')" || true
  119. [ "$VERSION" ] && echo "VERSION=$VERSION" >> $GITHUB_ENV || echo "VERSION=$(date +'%m.%d')" >> $GITHUB_ENV
  120. - name: Clone source code
  121. working-directory: /workdir
  122. run: |
  123. if [[ ${{matrix.target}} == "ipq807x" ]];then
  124. git clone https://github.com/robimarko/openwrt -b ipq807x-5.15-pr --depth 1
  125. else
  126. REPO_BRANCH="$((curl -gs -H 'Content-Type: application/json' \
  127. -H "Authorization: Bearer ${{ secrets.REPO_TOKEN }}" \
  128. -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 v22 | tail -n 1)"
  129. git clone $REPO_URL -b $REPO_BRANCH openwrt
  130. if [ "${{ env.REPO_BRANCH }}" ]; then
  131. cd openwrt
  132. git checkout ${{ env.REPO_BRANCH }}
  133. fi
  134. fi
  135. ln -sf /workdir/openwrt $GITHUB_WORKSPACE/openwrt
  136. - name: Load custom configuration
  137. run: |
  138. cp -rf devices/common/. openwrt/
  139. cp -rf devices/${{matrix.target}}/. openwrt/
  140. cp -rf devices openwrt/
  141. cd openwrt
  142. chmod +x devices/common/$DIY_SH
  143. /bin/bash "devices/common/$DIY_SH"
  144. if [ -f "devices/${{matrix.target}}/$DIY_SH" ]; then
  145. chmod +x devices/${{matrix.target}}/$DIY_SH
  146. /bin/bash "devices/${{matrix.target}}/$DIY_SH"
  147. fi
  148. cp -Rf ./diy/* ./ || true
  149. if [ -f "devices/${{matrix.target}}/default-settings" ]; then
  150. echo >> package/*/*/my-default-settings/files/etc/uci-defaults/99-default-settings
  151. cat devices/${{matrix.target}}/default-settings >> package/*/*/my-default-settings/files/etc/uci-defaults/99-default-settings
  152. fi
  153. cp -f devices/common/$CONFIG_FILE .config
  154. if [ -f "devices/${{matrix.target}}/$CONFIG_FILE" ]; then
  155. echo >> .config
  156. cat devices/${{matrix.target}}/$CONFIG_FILE >> .config
  157. fi
  158. - name: Apply patches
  159. run: |
  160. cd openwrt
  161. find "devices/common/patches" -type f ! -name 'china_mirrors.patch' -name '*.patch' -print0 | sort -z | xargs -I % -t -0 -n 1 sh -c "cat '%' | patch -d './' --no-backup-if-mismatch --merge -p1 -E --forward"
  162. if [ -n "$(ls -A "devices/${{matrix.target}}/patches" 2>/dev/null)" ]; then
  163. find "devices/${{matrix.target}}/patches" -type f -name '*.patch' -print0 | sort -z | xargs -I % -t -0 -n 1 sh -c "cat '%' | patch -d './' --no-backup-if-mismatch --merge -p1 -E --forward"
  164. fi
  165. - name: Default PPPOE Setting
  166. if: env.PPPOE_USERNAME && env.PPPOE_PASSWD
  167. run: |
  168. sed -i '$i uci set network.wan.username=${{ env.PPPOE_USERNAME }}' openwrt/package/*/*/my-default-settings/files/etc/uci-defaults/95-default-settings
  169. sed -i '$i uci set network.wan.password=${{ env.PPPOE_PASSWD }}' openwrt/package/*/*/my-default-settings/files/etc/uci-defaults/95-default-settings
  170. sed -i '$i uci commit network' openwrt/package/*/*/my-default-settings/files/etc/uci-defaults/95-default-settings
  171. - name: Defconfig
  172. run: |
  173. cd openwrt
  174. make defconfig
  175. cat .config
  176. - name: SSH connection to Actions
  177. uses: kiddin9/debugger-action@master
  178. if: contains(github.event.action, 'ssh')
  179. - name: Download package
  180. id: package
  181. run: |
  182. cd openwrt
  183. make download -j$(($(nproc)+1)) &
  184. sleep 5
  185. - name: Cache
  186. uses: klever1988/cachewrtbuild@main
  187. with:
  188. ccache: 'true'
  189. clean: ${{ contains(github.event.action, 'nocache') }}
  190. prefix: ${{ github.workspace }}/openwrt
  191. - name: Compile the firmware
  192. id: compile
  193. run: |
  194. shopt -s extglob
  195. cd openwrt
  196. rm -rf staging_dir/!(*${{ env.MTARGET }}*|host)
  197. df -hT
  198. echo -e "$(($(nproc)+1)) thread compile"
  199. make -j$(($(nproc)+1)) || make -j1 V=s || (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";exit 1)
  200. sed -i "s/# CONFIG_IB is not set/CONFIG_IB=y/" .config
  201. rm -rf staging_dir/toolchain-*/bin/*openwrt-linux-musl-lto-dump
  202. rm -rf staging_dir/toolchain-*/initial
  203. - name: Check space usage
  204. run: df -hT
  205. - name: Organize files
  206. id: organize
  207. continue-on-error: true
  208. run: |
  209. shopt -s extglob
  210. mkdir -p firmware/${{matrix.target}}
  211. cp -rf openwrt/bin/targets/*/*/*{combined,sysupgrade}* ./firmware/${{matrix.target}}/ || true
  212. cd openwrt/bin/targets/*/*/
  213. mv -f profiles.json profiles.json.b
  214. cp $GITHUB_WORKSPACE/openwrt/.config ${{matrix.target}}.config || true
  215. cp $GITHUB_WORKSPACE/openwrt/build_dir/target-*/linux-*/linux-*/.config ${{matrix.target}}_kernel.config || true
  216. mv -f packages ${{ env.KERNEL }}
  217. mkdir packages
  218. cp -rf ${{ env.KERNEL }}/Packages* packages/
  219. cd -
  220. rename -v "s/openwrt-/${{ env.VERSION }}-openwrt-/" ./firmware/*/* || true
  221. rename -v "s/friendlyarm_//" ./firmware/*/*gz || true
  222. rename -v "s/embedfire_//" ./firmware/*/*gz || true
  223. rename -v "s/xiaomi_redmi-router/redmi/" ./firmware/*/*bin || true
  224. Emoji=("🎉" "🤞" "✨" "🎁" "🎈" "🎄" "🎨" "💋" "🍓" "🍕" "🍉" "💐" "🌴" "🚀" "🛸" "🗽" "⛅" "🌈" "🔥" "⛄" "🐶" "🏅" "🦄" "🐤")
  225. echo "EMOJI=${Emoji[$[$RANDOM % ${#Emoji[@]}]]}" >> $GITHUB_ENV
  226. if [ ${{matrix.target}} == "x86_64" ]; then
  227. echo "DOCKERTAG=${{ secrets.DOCKER_ID }}/openwrt-nginx:latest" >> $GITHUB_ENV
  228. echo "NOTICE=请分配不少于1G的存储容量" >> $GITHUB_ENV
  229. fi
  230. - name: Deploy firmware to server
  231. uses: easingthemes/ssh-deploy@main
  232. if: env.SSH_PRIVATE_KEY && contains(github.event.action, 'toser')
  233. with:
  234. SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
  235. ARGS: "-avzr --exclude="
  236. SOURCE: firmware/
  237. REMOTE_HOST: op.supes.top
  238. REMOTE_USER: root
  239. TARGET: "/www/wwwroot/op.supes.top/firmware/"
  240. - name: Deploy imagebuilder to server
  241. uses: easingthemes/ssh-deploy@main
  242. if: env.SSH_PRIVATE_KEY && ! contains(github.event.action, 'noser')
  243. with:
  244. SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }}
  245. ARGS: "-avzr"
  246. SOURCE: openwrt/bin/targets
  247. REMOTE_HOST: op.supes.top
  248. REMOTE_USER: root
  249. TARGET: "/www/wwwroot/op.supes.top/releases/tmp/"
  250. - name: Upload firmware for artifact
  251. uses: actions/upload-artifact@main
  252. continue-on-error: true
  253. if: env.UPLOAD_FIRMWARE_FOR_ARTIFACT == 'true'
  254. with:
  255. name: ${{ env.VERSION }}_${{matrix.target}}
  256. path: |
  257. openwrt/bin/targets/
  258. - name: Upload firmware to cowtransfer
  259. if: env.UPLOAD_FIRMWARE_TO_COWTRANSFER == 'true'
  260. continue-on-error: true
  261. run: |
  262. curl -fsSL git.io/file-transfer | sh
  263. cowurl=$(./transfer cow --block 2621440 -s --no-progress ${FIRMWARE})
  264. cowurl=$(echo $cowurl | grep -o -E "https[^ ]*")
  265. echo "COWURL=$cowurl" >> $GITHUB_ENV
  266. echo "Download Link: ${{ env.EMOJI }} $cowurl ${{ env.EMOJI }} 🚀"
  267. - name: Upload firmware to WeTransfer
  268. if: env.UPLOAD_FIRMWARE_TO_WETRANSFER == 'true' && ! contains(github.event.action, 'noup')
  269. continue-on-error: true
  270. run: |
  271. curl -fsSL git.io/file-transfer | sh
  272. wetrans=$(./transfer wet -s -p 16 --no-progress ${FIRMWARE})
  273. wetrans=$(echo $wetrans | grep -o -E "https[^ ]*")
  274. echo "WETRANS=$wetrans" >> $GITHUB_ENV
  275. echo "Download Link: ${{ env.EMOJI }} $wetrans ${{ env.EMOJI }} 🚀"
  276. - name: Create release
  277. id: create_release
  278. if: env.REPO_TOKEN && env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true'
  279. continue-on-error: true
  280. run: |
  281. echo -e "墙内加速下载 🚀:\n" >> release.txt
  282. echo -e "[腾讯云] (https://op.supes.top/firmware/${{matrix.target}}/ ☁)\n" >> release.txt
  283. [ ${{ env.WETRANS }} ] && echo -e "[WeTransfer] (${{ env.WETRANS }} 🗽)\n" >> release.txt
  284. [ ${{ env.COWURL }} ] && echo -e "[奶牛上传] (${{ env.COWURL }} 🐮)\n" >> release.txt
  285. [ ${{ env.NOTICE }} ] && echo -e "${{ env.NOTICE }}" >> release.txt || true
  286. - name: Upload firmware for release
  287. uses: softprops/action-gh-release@master
  288. continue-on-error: true
  289. if: env.REPO_TOKEN && env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true'
  290. env:
  291. GITHUB_TOKEN: ${{ secrets.REPO_TOKEN }}
  292. with:
  293. files: "${{ env.FIRMWARE }}/*"
  294. name: ${{ env.date2 }} ${{matrix.target}} ${{ env.EMOJI }}
  295. tag_name: ${{ env.date }}_${{matrix.target}}
  296. body_path: release.txt
  297. - name: Set Up Docker Buildx
  298. uses: docker/setup-buildx-action@master
  299. if: env.DOCKER_ID && env.DOCKER_PASSWD
  300. - name: Login To DockerHub
  301. uses: docker/login-action@master
  302. if: env.DOCKER_ID && env.DOCKER_PASSWD
  303. with:
  304. username: ${{ secrets.DOCKER_ID }}
  305. password: ${{ secrets.DOCKER_PASSWD }}
  306. - name: Build and push docker image
  307. uses: docker/build-push-action@master
  308. continue-on-error: true
  309. if: env.DOCKER_ID && env.DOCKER_PASSWD && ! contains(github.event.action, 'noser') && github.event.client_payload.target == 'x86_64'
  310. with:
  311. platforms: ${{ env.ARCH }}
  312. file: Dockerfile
  313. context: .
  314. push: true
  315. tags: |
  316. ${{ secrets.DOCKER_ID }}/openwrt-nginx:${{ matrix.target }}
  317. ${{ env.DOCKERTAG }}
  318. - name: WeChat notification
  319. continue-on-error: true
  320. if: env.SCKEY
  321. run: |
  322. # [ 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}}编译失败😂
  323. - name: Telegram notification
  324. if: env.TELEGRAM_TOKEN && ! contains(github.event.action, 'notg')
  325. continue-on-error: true
  326. run: |
  327. curl -k --data chat_id="${{ env.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${{ env.TELEGRAM_TOKEN }}/sendMessage"
  328. - name: Delete workflow runs
  329. uses: GitRML/delete-workflow-runs@main
  330. continue-on-error: true
  331. with:
  332. retain_days: 100
  333. keep_minimum_runs: 0
  334. - name: Remove old Releases
  335. uses: dev-drprasad/delete-older-releases@master
  336. continue-on-error: true
  337. if: env.UPLOAD_FIRMWARE_FOR_RELEASE == 'true' && !cancelled()
  338. with:
  339. keep_latest: 15
  340. delete_tags: true
  341. env:
  342. GITHUB_TOKEN: ${{ secrets.REPO_TOKEN }}