From 3bcd9089ca772de2196c040a72b0efc8f5971a0c Mon Sep 17 00:00:00 2001 From: smlt Date: Mon, 5 Aug 2024 17:28:31 +0200 Subject: [PATCH] Update deploy workflow to use DigitalOcean Spaces. --- .github/workflows/deploy.yaml | 50 ++++++++++++++++++++++------------- 1 file changed, 31 insertions(+), 19 deletions(-) diff --git a/.github/workflows/deploy.yaml b/.github/workflows/deploy.yaml index 2a6033a..a2411ef 100644 --- a/.github/workflows/deploy.yaml +++ b/.github/workflows/deploy.yaml @@ -13,6 +13,14 @@ jobs: name: Deploy CSS runs-on: ubuntu-latest + permissions: + pages: write + id-token: write + + environment: + name: github-pages + url: ${{ steps.deployment.outputs.page_url }} + steps: - name: Checkout uses: actions/checkout@v1 @@ -23,29 +31,33 @@ jobs: - name: Build run: ./build.sh - - name: Deploy (GitHub Pages) - uses: JamesIves/github-pages-deploy-action@4.1.4 + - name: Upload artifact + uses: actions/upload-pages-artifact@v3 with: - branch: gh-pages - folder: dist + path: dist/ - - name: Deploy (S3) - uses: emmiegit/s3-sync-action@main - with: - args: --delete + - name: Deploy (GitHub Pages) + uses: actions/deploy-pages@v4 + id: deployment + + - name: Upload to S3 + run: | + export sync_args=( "--delete" "--acl" "public-read" "dist" "s3://${{ vars.AWS_S3_BUCKET }}/${{ env.BUCKET_PATH }}" ) + # Manually set content-types for anything aws-cli can't guess correctly + aws s3 sync ${sync_args[@]} --exclude "*" --include "*.css" --content-type "text/css; charset=utf-8" + aws s3 sync ${sync_args[@]} --exclude "*.css" env: - AWS_S3_BUCKET: ${{ vars.AWS_S3_BUCKET }} - AWS_REGION: ${{ vars.AWS_REGION }} AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} - SOURCE_DIR: dist - DEST_DIR: ${{ env.BUCKET_PATH }} + AWS_ENDPOINT_URL: 'https://${{ vars.DIGITALOCEAN_SPACES_REGION }}.digitaloceanspaces.com' + AWS_DEFAULT_REGION: 'us-east-1' - - name: Invalidate CloudFront - uses: chetan/invalidate-cloudfront-action@v2 + - name: Install doctl + uses: digitalocean/action-doctl@v2 + with: + token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN }} + + - name: Invalidate Spaces Cache + run: doctl compute cdn flush $DIGITALOCEAN_CDN_ID env: - DISTRIBUTION: ${{ secrets.CF_DISTRIBUTION }} - PATHS: /${{ env.BUCKET_PATH }}/ /${{ env.BUCKET_PATH }}/* - AWS_REGION: ${{ vars.AWS_REGION }} - AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} - AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + DIGITALOCEAN_CDN_ID: ${{ vars.DIGITALOCEAN_CDN_ID }}