Skip to content

guardian/actions-static-site

Repository files navigation

@guardian/actions-static-site V3

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>).

Inputs

app string (required):

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'.

domain string (required):

The domain should be a Guardian-owned domain. For internal tools, [app].gutools.co.uk is recommended but check it is free first!

artifact string (optional - default='artifact')

Name of the artifact containing the static resources. Should be uploaded in an earlier workflow step.

Architecture

flowchart LR
    A[Shared ALB] -->B(EC2) -->C(S3)
Loading

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