Deploy to docs-content.oniudra.cc #55
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Deploy to docs-content.oniudra.cc | |
on: | |
workflow_dispatch: | |
push: | |
branches: | |
- ghaction | |
concurrency: | |
group: deploy-staging | |
cancel-in-progress: true | |
permissions: | |
id-token: write | |
contents: read | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
environment: staging | |
env: | |
REPO_ACCESS_TOKEN: ${{ secrets.REPO_ACCESS_TOKEN }} | |
APP_ENV: staging | |
steps: | |
- uses: actions/checkout@v4 | |
with: | |
fetch-depth: 1 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 18 | |
cache: "npm" | |
cache-dependency-path: "**/package-lock.json" | |
- name: Render Datasheets | |
run: cd ${GITHUB_WORKSPACE}/scripts/datasheet-rendering;./render-datasheets.sh | |
- name: Copy Static Files | |
run: | | |
mkdir -p static/resources/datasheets static/resources/schematics static/resources/pinouts static/resources/models | |
find ./content/hardware -type f -name "*-schematics.pdf" -exec cp {} ./static/resources/schematics/ \; | |
find ./content/hardware -type f -name "*-datasheet.pdf" -exec cp {} ./static/resources/datasheets/ \; | |
find ./content/hardware -type f -name "*-full-pinout.pdf" -exec cp {} ./static/resources/pinouts/ \; | |
find ./content/hardware -type f -name "*-pinout.png" -exec cp {} ./static/resources/pinouts/ \; | |
find ./content/hardware -type f -name "*-step.zip" -exec cp {} ./static/resources/models/ \; | |
- name: Gatsby main cache | |
uses: actions/cache@v4 | |
id: gatsby-cache-folder | |
with: | |
path: .cache | |
key: ${{ runner.os }}-cache-gatsby-${{ github.ref_name }} | |
restore-keys: | | |
${{ runner.os }}-cache-gatsby-main | |
- name: Gatsby Public Folder | |
uses: actions/cache@v4 | |
id: gatsby-public-folder | |
with: | |
path: public/ | |
key: ${{ runner.os }}-public-gatsby-${{ github.ref_name }} | |
restore-keys: | | |
${{ runner.os }}-public-gatsby-main | |
- run: npm install | |
- run: npm run build | |
- name: Clean up node_modules | |
run: rm -rf node_modules | |
- name: Configure AWS credentials from Staging account | |
uses: aws-actions/configure-aws-credentials@v4 | |
with: | |
role-to-assume: ${{ secrets.STAGING_IAM_ROLE }} | |
aws-region: us-east-1 | |
# - name: Sync all cacheable assets | |
# run: aws s3 sync --cache-control "public, max-age=31536000, immutable" --include "*.css" --include="*.js" --include="*.gif" --include="*.png" --include="*.svg" --exclude "*.html" --exclude="sw.js" --exclude="*.json" --exclude="*.pdf" --delete public/ s3://${{ secrets.STAGING_BUCKET_NAME }}/ | |
# - name: Sync all non-cacheable assets | |
# # Don't cache any HTML or JSON file: they should always be up-to-dates | |
# run: aws s3 sync --cache-control "public, max-age=0, must-revalidate" --include "*.html" --include="sw.js" --include="*.json" --include "*.css" --exclude="*.js" --exclude="*.gif" --exclude="*.png" --exclude="*.svg" --exclude="*.pdf" --delete public/ s3://${{ secrets.STAGING_BUCKET_NAME }}/ | |
# - name: Sync PDF | |
# run: aws s3 sync --cache-control "public, max-age=86400, must-revalidate" --include "*.pdf" --exclude="*.js" --exclude="*.gif" --exclude="*.png" --exclude="*.svg" --exclude="*.css" --exclude="*.html" --exclude="*.json" --exclude="sw.json" --delete public/ s3://${{ secrets.STAGING_BUCKET_NAME }}/ | |
# - name: Purge cache on CloudFlare | |
# run: | | |
# curl -X POST "https://api.cloudflare.com/client/v4/zones/${{ secrets.CLOUDFLARE_ZONE }}/purge_cache" \ | |
# -H "Authorization: Bearer ${{ secrets.CLOUDFLARE_PURGE_API_TOKEN }}" \ | |
# -H "Content-Type: application/json" \ | |
# --data '{"prefixes":["${{ vars.DATASHEETS_BASE_URL }}"]}' | |
- name: Sync all cacheable assets | |
run: aws s3 sync --cache-control "public, max-age=31536000, immutable" --include "*.css" --include="*.js" --include="*.gif" --include="*.png" --include="*.svg" --exclude "*.html" --exclude="sw.js" --exclude="*.json" --delete public/ s3://${{ secrets.STAGING_BUCKET_NAME }}/ | |
- name: Sync all non-cacheable assets | |
# Don't cache any HTML or JSON file: they should always be up-to-dates | |
run: aws s3 sync --cache-control "public, max-age=0, must-revalidate" --include "*.html" --include="sw.js" --include="*.json" --include "*.css" --exclude="*.js" --exclude="*.gif" --exclude="*.png" --exclude="*.svg" --delete public/ s3://${{ secrets.STAGING_BUCKET_NAME }}/ | |