1
0

release.yml 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. name: release
  2. on:
  3. push:
  4. branches:
  5. - master
  6. env:
  7. DISCORD_HOOK_URL: ${{ secrets.DISCORD_HOOK_URL }}
  8. GITHUB_SHA: ${{ github.sha }}
  9. jobs:
  10. release:
  11. name: Build Release
  12. runs-on: ubuntu-latest
  13. permissions:
  14. id-token: write
  15. contents: write
  16. steps:
  17. - uses: actions/checkout@v4
  18. with:
  19. ref: master
  20. - name: Retrieve Certs
  21. run: |
  22. ./script/retrieve_certs
  23. env:
  24. GIT_USER: ${{ secrets.GIT_USER }}
  25. GIT_AUTH: ${{ secrets.GIT_AUTH }}
  26. GIT_URL: ${{ secrets.GIT_URL }}
  27. CERTS_KEY: ${{ secrets.CERTS_KEY }}
  28. - name: Set Release Tag
  29. run: echo "release_tag=$(cat version.txt)" >> $GITHUB_ENV
  30. - name: Build release
  31. run: |
  32. ./script/build_release release
  33. - name: Configure AWS credentials
  34. uses: aws-actions/configure-aws-credentials@v4
  35. with:
  36. role-to-assume: ${{ secrets.AWS_ROLE_PROD }}
  37. aws-region: ${{ secrets.AWS_ACCESS_REGION }}
  38. - name: Deploy master to release bucket
  39. run: |
  40. aws s3 sync --no-progress --acl public-read s3out s3://${{ secrets.AWS_S3_BUCKET_PROD }}/${{ env.release_tag }}
  41. - name: Deploy master to rolling bucket
  42. run: |
  43. aws s3 sync --no-progress --acl public-read s3out-latest s3://${{ secrets.AWS_S3_BUCKET_PROD }}
  44. - name: Invalidate Cloudfront
  45. run: |
  46. aws cloudfront create-invalidation --distribution-id ${{ secrets.CLOUDFRONT_DIST_ID_PROD }} --paths "/*" "/ipxe/*" "/sigs/*"
  47. - name: Tag Release
  48. run: |
  49. ./script/tag ${{ env.release_tag }}
  50. - name: Extract release notes
  51. id: extract-release-notes
  52. uses: ffurrer2/extract-release-notes@v2
  53. - name: Create Release and Upload Assets
  54. uses: svenstaro/upload-release-action@v2
  55. with:
  56. file: githubout/*
  57. file_glob: true
  58. overwrite: true
  59. prerelease: false
  60. release_name: ${{ env.release_tag }}
  61. repo_token: ${{ secrets.GITHUB_TOKEN }}
  62. tag: ${{ env.release_tag }}
  63. body: ${{ steps.extract-release-notes.outputs.release_notes }}
  64. - name: Notify Discord on failure
  65. if: failure()
  66. run: |
  67. ./script/message failure
  68. - name: Notify Discord on completion
  69. if: success()
  70. run: |
  71. ./script/message live-push