Skip to content
This repository has been archived by the owner on Sep 11, 2020. It is now read-only.

Latest commit

 

History

History
63 lines (35 loc) · 4.35 KB

README.md

File metadata and controls

63 lines (35 loc) · 4.35 KB

Docker Static Site Generator

Docker Static Site Generator is a docker contained, static (HTML) site generator that can optionally upload to S3 and CloudFront. Local development is done via a Node Express server, with a Gulp file included to provide the following tooling and optimisations:

  • SASS compiling, autoprefixing and minification
  • Image optimisation
  • Asset cache-busting
  • Critical path CSS 😅
  • Foundation for Sites

In addition, Docker Static Site Generator can also publish your generated files straight to S3 with correct cache-control flags, as well as invalidate associated CloudFront distribution cache.

Intended purpose

This is for building static HTML sites, using decent defaults and a few handy tools. Hosting websites on S3 and CloudFlare is also very low cost. This is not intended for building complex sites, or sites that require any sort of dynamic logic, it generates static files only.

Requirements

You'll need the following to get up and running:

  • Docker
  • Docker Compose
  • An AWS account (optional)

Docker setup and first run

Run the following command to build and run the Docker container, the first time you run this it will build the container:

$ docker-compose up

You will see the output from the build process and running process, to stop it you can use Ctrl + C or $ docker-compose down. To interact with the running container, you can exec as follows:

$ docker exec -it dockerstaticsitegenerator_app1 /bin/bash

Note, you may need to change the name of the container if you are running several, check using $ docker ps.

You should now be able to see the site running at http://localhost:3000/.

Interacting with Gulp, NPM etc

Gulp is run the first time docker-compose is built, and when you need to run it again, or install any sort of packages using NPM, you need to exec into the container. This is simply a matter of issuing the following command:

$ docker exec -it dockerstaticsitegenerator_app1 /bin/bash

Note, you may need to change the name of the container if you are running several, check using $ docker ps.

From there you can simply run $ gulp or $ gulp watch, as well as install NPM packages.

Developing sites

You can develop sites by adding or editing the files inside app/src, and you can do it from your normal filesystem using your normal editor (i.e. there is no need to exec into the docker container to edit files are synced). Currently there is no template engine or other helpers, so (keeping it old school) you just create and edit any HTML files and other assets as needed. Images and SASS should be stored in the assets folder. When gulp is run (either as a task or in watch mode) it compiles all files in the src directory into the dist directory, which is also the folder where localhost:3000 is served from. Note, depending on how complex you make your build process, you won't see any changes until they have been compiled.

Publishing to S3

In order to publish to an S3 bucket, you will need to create a aws-credentials.json file. Copy the existing app/aws-credentials.json.example file and save it as aws-credentials.json, adding the details needed. It is highly recommended that you create a dedicated IAM user to use for the token and secret, and restrict their access to only the bucket (and optionally CloudFront). Note for obvious reasons your AWS credentials should be kept out of your git repo, the file is therefore excluded curtosy of a gitignore rule.

Your S3 bucket will need to be setup for static website hosting, with an index.html specified and optionally a 404.html (example included). Any time you publish, the bucket will be emptied, so ensure you have created a bucket solely for the purpose of static website hosting and not containing any files you don't want to be removed when you publish.

To upload to your S3 website bucket, just run $ gulp publish, only the files which have changed will be uploaded.

Invalidate CloudFront cache

If you have your S3 bucket connected to a CloudFront distribution (which is the recommended way to do it), you will want to invalidate the cache when new files are uploaded. Provided your IAM user has permissions to do so, you can include the CloudFront distribution ID in the aws-credentials.json file and run $ gulp invalidate. Only files which are known to have changed will be invalidated.