release.yml 2.2 KB

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