Action to provision and serve a static site with Google Auth and a custom domain.
Behind the scenes the action outputs Cloudformation and RiffRaff configuration for your project. The marginal cost of a site is minimal - just the storage of your files in S3 and data transfer costs - as the core infrastructure is shared.
Note: your domain must be registered with the Google project for the Google
auth callback to work - ping it on the DevX Stream
channel and we can quickly add this for you.
You will also need to add your repo to riffraff-platform, with riffraff project name deploy::*appname*
- for example guardian/riffraff-platform#399.
You will need to merge the riffraff-platform PR before you start creating your @guardian/actions-static-site
job otherwise the build will fail as your repository expects to have GU_RIFF_RAFF_ROLE_ARN
in your respository secrets and that gets generated after the merge.
Also it would be good to know that @guardian/actions-static-site
has just PROD environment. For more details check #41.
Any paths ending in /_prout
will skip authentication, so feel free to add the git hash as a file called _prout
and then wire it up to PRout - for example guardian/galaxies#102.
name: example
on:
pull_request:
workflow_dispatch:
push:
branches:
- main
jobs:
example:
runs-on: ubuntu-latest
# Required for Riffraff upload (which writes to AWS)
permissions:
id-token: write
contents: read
pull-requests: write
steps:
# ... (Build your static site.)
# Then upload it as an artifact
- uses: actions/upload-artifact@v4
with:
path: my-site
# Then invoke this action (replacing app and domain)
- uses: guardian/actions-static-site@v3
with:
app: example
domain: example.gutools.co.uk
roleArn: ${{ secrets.GU_RIFF_RAFF_ROLE_ARN }}
githubToken: ${{ secrets.GITHUB_TOKEN }}
Each run of actions-static-site uses actions-riff-raff to create a new build in
a Riff Raff project which deploys your static site. This allows you to configure
deployment as usual using Riff Raff, for example by setting up continuous
deployment to deploy any new builds on the main branch. It also means your
repository needs to have the necessary access to write to that Riff Raff project
(deploy::<app>
).
The app name. Used for the Riffraff deployment name and also to tag AWS resources. Typically this would be the first part of your domain name - e.g. 'example' for 'example.gutools.co.uk'.
The domain should be a Guardian-owned domain. For internal tools,
[app].gutools.co.uk
is recommended but check it is free first!
Name of the artifact containing the static resources. Should be uploaded in an earlier workflow step.
flowchart LR
A[Shared ALB] -->B(EC2) -->C(S3)
A shared ALB is used for all static site instances. The action uploads your files to the shared S3 bucket with your domain as the key prefix on files, and also creates a CNAME record and cert, and connects those to the ALB.
The EC2 instance checks the auth token and serves files for the site by reading the HOST header and amending the path in S3 as appropriate.
E.g.
GET devx.gutools.co.uk/css/main.css
-> S3:[bucket-name]/devx.gutools.co.uk/css/main.css