diff --git a/README.md b/README.md index 967ab38..67232cb 100644 --- a/README.md +++ b/README.md @@ -1,64 +1,209 @@ -# Ministry of Justice Template Repository +# NVVS DevOps Containers Repository [![repo standards badge](https://img.shields.io/endpoint?labelColor=231f20&color=005ea5&style=for-the-badge&label=MoJ%20Compliant&url=https%3A%2F%2Foperations-engineering-reports.cloud-platform.service.justice.gov.uk%2Fapi%2Fv1%2Fcompliant_public_repositories%2Fendpoint%2Ftemplate-repository&logo=)](https://operations-engineering-reports.cloud-platform.service.justice.gov.uk/public-report/template-repository) -This template repository equips you with the default initial files required for a Ministry of Justice GitHub repository. +## Docker container for local terraform development -## Included Files +Here the NVVS DevOps development container is defined. -The repository comes with the following preset files: +It can be used locally to enable a consistent development experience across platforms +(Linux, Windows, MacOS (Intel & M1 ARM)). -- LICENSE -- .gitignore -- CODEOWNERS -- dependabot.yml -- GitHub Actions example file -- Ministry of Justice Compliance Badge (Public repositories only) +### How to build -## Setup Instructions +Prerequisite Docker installed, Make. -Once you've created your repository using this template, ensure the following steps: +```shell +make build +``` -### Update README +### How to use -Edit this README.md file to document your project accurately. Take the time to create a clear, engaging, and informative README.md file. Include information like what your project does, how to install and run it, how to contribute, and any other pertinent details. +Suggestion for use with [AWS-VAULT](https://ministryofjustice.github.io/nvvs-devops/documentation/team-guide/best-practices/use-aws-sso.html#configure-aws-vault) -### Update repository description +#### Freeflow -After you've created your repository, GitHub provides a brief description field that appears on the top of your repository's main page. This is a summary that gives visitors quick insight into the project. Using this field to provide a succinct overview of your repository is highly recommended. +Create an alias for use with the local build -This description and your README.md will be one of the first things people see when they visit your repository. It's a good place to make a strong, concise first impression. Remember, this is often visible in search results on GitHub and search engines, so it's also an opportunity to help people discover your project. +```shell +alias toold='docker run --rm -ti -v $(pwd):/data --env-file <(aws-vault exec $AWS_PROFILE -- env | grep ^AWS_) ministryofjustice/nvvs/terraforms:latest' +``` -### Grant Team Permissions +In terraform directory run -Assign permissions to the appropriate Ministry of Justice teams. Ensure at least one team is granted Admin permissions. Whenever possible, assign permissions to teams rather than individual users. +```shell +toold +``` -### Read about the GitHub repository standards +To use the version hosted on the [GitHub Container Registry](https://github.blog/tag/container-registry/) attached to this repository/ -Familiarise yourself with the Ministry of Justice GitHub Repository Standards. These standards ensure consistency, maintainability, and best practices across all our repositories. +```shell +alias tooldgh='docker run --rm -ti -v $(pwd):/data --env-file <(aws-vault exec $AWS_PROFILE -- env | grep ^AWS_) ghcr.io/ministryofjustice/nvvs/terraforms:v0.2.0' +``` -You can find the standards [here](https://operations-engineering.service.justice.gov.uk/documentation/services/repository-standards.html). +### Tools included -Please read and understand these standards thoroughly and enable them when you feel comfortable. +See the [Dockerfile](./Dockerfile) for full details. However initially this container is a large utility container to reduce developer friction while upgrading the repositories to a consistent version(s) of Terraform. -### Modify the GitHub Standards Badge +- Terraform (via TFENV) +- AWS CLI v2 +- TFLINT +- kubectl +- helm -Once you've ensured that all the [GitHub Repository Standards](https://operations-engineering.service.justice.gov.uk/documentation/services/repository-standards.html) have been applied to your repository, it's time to update the Ministry of Justice (MoJ) Compliance Badge located in the README file. +### Create tagged release -The badge demonstrates that your repository is compliant with MoJ's standards. Please follow these [instructions](https://operations-engineering.service.justice.gov.uk/documentation/runbooks/services/add-repo-badge.html) to modify the badge URL to reflect the status of your repository correctly. +NOTE: This needs refining. -**Please note** the badge will not function correctly if your repository is internal or private. In this case, you may remove the badge from your README. +- Push the branch to github and get a pull request approved. +- Merge to main +- Depending on the increment run `make tag SEMVAR=[ patch | minor | major ]` -### Manage Outside Collaborators +## Example usage in Makefile -To add an Outside Collaborator to the repository, follow the guidelines detailed [here](https://github.com/ministryofjustice/github-collaborators). +This is an example of how it can be used with one of the NVVS DevOps Terraform projects. -### Update CODEOWNERS +```makefile +#!make +.DEFAULT_GOAL := help +SHELL := '/bin/bash' -(Optional) Modify the CODEOWNERS file to specify the teams or users authorized to approve pull requests. +CURRENT_TIME := `date "+%Y.%m.%d-%H.%M.%S"` +TERRAFORM_VERSION := `cat versions.tf 2> /dev/null | grep required_version | cut -d "\\"" -f 2 | cut -d " " -f 2` -### Configure Dependabot +LOCAL_IMAGE := ministryofjustice/nvvs/terraforms:latest +DOCKER_IMAGE := ghcr.io/ministryofjustice/nvvs/terraforms:v0.2.0 -Adapt the dependabot.yml file to match your project's [dependency manager](https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#package-ecosystem) and to enable [automated pull requests for package updates](https://docs.github.com/en/code-security/supply-chain-security). +DOCKER_RUN := @docker run --rm \ + --env-file <(aws-vault exec $$AWS_PROFILE -- env | grep ^AWS_) \ + --env-file <(env | grep ^TF_VAR_) \ + --env-file <(env | grep ^ENV) \ + -e TFENV_TERRAFORM_VERSION=$(TERRAFORM_VERSION) \ + -v `pwd`:/data \ + --workdir /data \ + --platform linux/amd64 \ + $(DOCKER_IMAGE) -If your repository is private with no GitHub Advanced Security license, remove the .github/workflows/dependency-review.yml file. +DOCKER_RUN_IT := @docker run --rm -it \ + --env-file <(aws-vault exec $$AWS_PROFILE -- env | grep ^AWS_) \ + --env-file <(env | grep ^TF_VAR_) \ + --env-file <(env | grep ^ENV) \ + -e TFENV_TERRAFORM_VERSION=$(TERRAFORM_VERSION) \ + -v `pwd`:/data \ + --workdir /data \ + --platform linux/amd64 \ + $(DOCKER_IMAGE) + +export DOCKER_DEFAULT_PLATFORM=linux/amd64 + +.PHONY: aws +aws: ## provide aws cli command as an arg e.g. (make aws AWSCLI_ARGUMENT="s3 ls") + $(DOCKER_RUN) /bin/bash -c "aws $$AWSCLI_ARGUMENT" + +.PHONY: shell +shell: ## Run Docker container with interactive terminal + $(DOCKER_RUN_IT) /bin/bash + +.PHONY: fmt +fmt: ## terraform fmt + $(DOCKER_RUN) terraform fmt --recursive + +.PHONY: init +init: ## terraform init (make init ENV_ARGUMENT=pre-production) NOTE: Will also select the env's workspace. + +## INFO: Do not indent the conditional below, make stops with an error. +ifneq ("$(wildcard .env)","") +$(info Using config file ".env") +include .env +init: -init +else +$(info Config file ".env" does not exist.) +init: -init-gen-env +endif + +.PHONY: -init-gen-env +-init-gen-env: + $(MAKE) gen-env + $(MAKE) -init + +.PHONY: -init +-init: + $(DOCKER_RUN) terraform init --backend-config="key=terraform.$$ENV.state" + $(MAKE) workspace-select + +.PHONY: init-upgrade +init-upgrade: ## terraform init -upgrade + $(DOCKER_RUN) terraform init -upgrade --backend-config="key=terraform.$$ENV.state" + +.PHONY: import +import: ## terraform import e.g. (make import IMPORT_ARGUMENT=module.foo.bar some_resource) + $(DOCKER_RUN) terraform import $$IMPORT_ARGUMENT + +.PHONY: workspace-list +workspace-list: ## terraform workspace list + $(DOCKER_RUN) terraform workspace list + +.PHONY: workspace-select +workspace-select: ## terraform workspace select + $(DOCKER_RUN) terraform workspace select $$ENV || \ + $(DOCKER_RUN) terraform workspace new $$ENV + +.PHONY: validate +validate: ## terraform validate + $(DOCKER_RUN) terraform validate + +.PHONY: plan-out +plan-out: ## terraform plan - output to timestamped file + $(DOCKER_RUN) terraform plan -no-color > $$ENV.$(CURRENT_TIME).tfplan + +.PHONY: plan +plan: ## terraform plan + $(DOCKER_RUN) terraform plan + +.PHONY: refresh +refresh: ## terraform refresh + $(DOCKER_RUN) terraform refresh + +.PHONY: output +output: ## terraform output (make output OUTPUT_ARGUMENT='--raw dns_dhcp_vpc_id') + $(DOCKER_RUN) terraform output -no-color $$OUTPUT_ARGUMENT + +.PHONY: apply +apply: ## terraform apply + $(DOCKER_RUN) terraform apply + $(DOCKER_RUN) /bin/bash -c "./scripts/publish_terraform_outputs.sh" + +.PHONY: state-list +state-list: ## terraform state list + $(DOCKER_RUN) terraform state list + +.PHONY: show +show: ## terraform show + $(DOCKER_RUN) terraform show -no-color + +.PHONY: destroy +destroy: ## terraform destroy + $(DOCKER_RUN) terraform destroy + +.PHONY: lock +lock: ## terraform providers lock (reset hashes after upgrades prior to commit) + rm .terraform.lock.hcl + $(DOCKER_RUN) terraform providers lock -platform=windows_amd64 -platform=darwin_amd64 -platform=linux_amd64 + +.PHONY: clean +clean: ## clean terraform cached providers etc + rm -rf .terraform/ terraform.tfstate* .env + +.PHONY: gen-env +gen-env: ## generate a ".env" file with the correct TF_VARS for the environment e.g. (make gen-env ENV_ARGUMENT=pre-production) + $(DOCKER_RUN) /bin/bash -c "./scripts/generate-env-file.sh $$ENV_ARGUMENT" + +.PHONY: tfenv +tfenv: ## tfenv pin - terraform version from versions.tf + tfenv use $(cat versions.tf 2> /dev/null | grep required_version | cut -d "\"" -f 2 | cut -d " " -f 2) && tfenv pin + +help: + @grep -h -E '^[a-zA-Z0-9_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}' + + +```