Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ntno/mkdocs-demo

example MkDocs project with GitHub Action CICD
https://github.com/ntno/mkdocs-demo

github-actions github-oidc mkdocs

Last synced: 19 days ago
JSON representation

example MkDocs project with GitHub Action CICD

Awesome Lists containing this project

README

        

# mkdocs-demo
Example project for creating/deploying a MkDocs website with GitHub Actions.

## live environments
### integration
temporary environments are created/destroyed with pull request open/close

url: posted to the pull request for review
status:
[![Test Pull Request](https://github.com/ntno/mkdocs-demo/actions/workflows/test-pr.yml/badge.svg)](https://github.com/ntno/mkdocs-demo/actions/workflows/test-pr.yml)

### development
url: [http://factually-settled-boxer-development.s3-website-us-east-1.amazonaws.com](http://factually-settled-boxer-development.s3-website-us-east-1.amazonaws.com)
status:
[![Deploy MkDocs to Development Environment](https://github.com/ntno/mkdocs-demo/actions/workflows/dev-deploy.yml/badge.svg?branch=main)](https://github.com/ntno/mkdocs-demo/actions/workflows/dev-deploy.yml)

### production
url: [http://factually-settled-boxer.s3-website-us-east-1.amazonaws.com](http://factually-settled-boxer.s3-website-us-east-1.amazonaws.com)
status:
[![Deploy MkDocs to Production Environment](https://github.com/ntno/mkdocs-demo/actions/workflows/prod-deploy.yml/badge.svg)](https://github.com/ntno/mkdocs-demo/actions/workflows/prod-deploy.yml)

## local development

ex: run server with ['dev/local'](variables.yml#L9-L12) site variables
`make serve env=dev region=local`

ex: run server with ['dev/us-east-1'](variables.yml#L15-L17) site variables
`make serve env=dev region=us-east-1`

ex: run server with ['prod/us-east-1'](variables.yml#L21-L25) site variables
`make serve env=prod region=us-east-1`

## prerequisites
- install docker and Make (for local development)
- set up OIDC provider in AWS console
- [Use OpenID Connect within your workflows to authenticate with Amazon Web Services.](https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/configuring-openid-connect-in-amazon-web-services)
- create S3 bucket for static website hosting
- create supporting cicd resources (S3 bucket for site artifacts and IAM roles for GitHub Action workflows to assume)

### infrastructure (onetime setup)

see terraform code in [`infra/`](infra/) for example on how to create required resources. [`ntno/tf-module-static-site-cicd`](https://github.com/ntno/tf-module-static-site-cicd) is used to create CICD IAM roles and artifact bucket.

```
make ubuntu
cd infra
make plan
make apply
```

- creates development and production site buckets
- creates IAM roles to support github action workflows