release.yml 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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. steps:
  14. - uses: actions/checkout@v2
  15. - name: Retrieve Certs
  16. run: |
  17. ./script/retrieve_certs
  18. env:
  19. GIT_USER: ${{ secrets.GIT_USER }}
  20. GIT_AUTH: ${{ secrets.GIT_AUTH }}
  21. GIT_URL: ${{ secrets.GIT_URL }}
  22. CERTS_KEY: ${{ secrets.CERTS_KEY }}
  23. - name: Set Release Tag
  24. run: echo "release_tag=$(cat version.txt)" >> $GITHUB_ENV
  25. - name: Build release
  26. run: |
  27. ./script/build_release release
  28. - name: Configure AWS credentials
  29. uses: aws-actions/configure-aws-credentials@v1
  30. with:
  31. aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
  32. aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
  33. aws-region: ${{ secrets.AWS_ACCESS_REGION }}
  34. - name: Deploy master to release bucket
  35. run: |
  36. aws s3 sync --no-progress --acl public-read s3out s3://${{ secrets.AWS_S3_BUCKET_PROD }}/${{ env.release_tag }}
  37. - name: Deploy master to rolling bucket
  38. run: |
  39. aws s3 sync --no-progress --acl public-read s3out-latest s3://${{ secrets.AWS_S3_BUCKET_PROD }}
  40. - name: Invalidate Cloudfront
  41. run: |
  42. aws cloudfront create-invalidation --distribution-id ${{ secrets.CLOUDFRONT_DIST_ID_PROD }} --paths "/*" "/ipxe/*"
  43. - name: Tag Release
  44. run: |
  45. ./script/tag ${{ env.release_tag }}
  46. - name: Create Release and Upload Assets
  47. uses: svenstaro/upload-release-action@v2
  48. with:
  49. file: githubout/*
  50. file_glob: true
  51. overwrite: true
  52. prerelease: false
  53. release_name: ${{ env.release_tag }}
  54. repo_token: ${{ secrets.GITHUB_TOKEN }}
  55. tag: ${{ env.release_tag }}
  56. - name: Notify Discord on failure
  57. if: failure()
  58. run: |
  59. ./script/message failure
  60. - name: Notify Discord on completion
  61. if: success()
  62. run: |
  63. ./script/message live-push