Skip to main content
TheFocus.Quest

Deploying a re-frame App

With a combination of AWS S3, CloudFront and GitHub Actions

The Gist

Delightfully simple, since shadow-cljs takes care of most of the operation. It boils down to:

GitHub Actions configuration

on:
  push:
    branches: [ test-github-actions ]

jobs:
  build-and-deploy:
    runs-on: ubuntu-latest
    environment: prod

    steps:
      - name: Configure AWS credentials
        uses: aws-actions/configure-aws-credentials@v4
        with:
          aws-access-key-id: $
          aws-secret-access-key: $
          aws-region: $

      - name: Checkout code
        uses: actions/checkout@v4

      - name: Use NodeJS 21.x
        uses: actions/setup-node@v4
        with:
          node-version: 21.x

      - name: Install npm dependencies
        run: npm install

      - name: Build release
        run: npm run release

      - name: Sync to S3
        run: |
          aws s3 sync ./resources/public s3://$ --delete

The Result

So you can now see the app in all its glory: https://d3r6lgifjuis4q.cloudfront.net/. This is the app repository.

Yeah... that still needs work.