generated from ministryofjustice/template-repository
-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
953a188
commit 487a0ad
Showing
15 changed files
with
678 additions
and
0 deletions.
There are no files selected for viewing
Validating CODEOWNERS rules …
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,259 @@ | ||
--- | ||
name: hmpps-intelligence-management | ||
on: | ||
push: | ||
branches: | ||
- main | ||
paths: | ||
- 'terraform/environments/hmpps-intelligence-management/**' | ||
- '.github/workflows/hmpps-intelligence-management.yml' | ||
pull_request: | ||
branches: | ||
- main | ||
types: [opened, edited, reopened, synchronize] | ||
paths: | ||
- 'terraform/environments/hmpps-intelligence-management/**' | ||
- '.github/workflows/hmpps-intelligence-management.yml' | ||
workflow_dispatch: | ||
inputs: | ||
action: | ||
description: 'Set either [deploy|destroy].' | ||
default: 'deploy' | ||
required: true | ||
type: string | ||
options: | ||
- deploy | ||
- destroy | ||
env: | ||
TF_IN_AUTOMATION: true | ||
AWS_REGION: "eu-west-2" | ||
ENVIRONMENT_MANAGEMENT: ${{ secrets.MODERNISATION_PLATFORM_ENVIRONMENTS }} | ||
permissions: | ||
id-token: write # This is required for requesting the JWT | ||
contents: read # This is required for actions/checkout | ||
defaults: | ||
run: | ||
shell: bash | ||
|
||
jobs: | ||
|
||
plan-dev-test: | ||
strategy: | ||
matrix: | ||
include: | ||
- environment: development | ||
- environment: test | ||
name: Plan - ${{ matrix.environment }} | ||
runs-on: ubuntu-latest | ||
if: github.ref != 'refs/heads/main' || github.event_name == 'workflow_dispatch' && github.event.inputs.action == 'deploy' | ||
env: | ||
TF_ENV: ${{ matrix.environment }} | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3.0 | ||
- name: Set Account Number | ||
run: echo "ACCOUNT_NUMBER=$(jq -r -e --arg account_name "${GITHUB_WORKFLOW}-${TF_ENV}" '.account_ids[$account_name]' <<< $ENVIRONMENT_MANAGEMENT)" >> $GITHUB_ENV | ||
- name: configure aws credentials | ||
uses: aws-actions/configure-aws-credentials@67fbcbb121271f7775d2e7715933280b06314838 # v1.7.0 | ||
with: | ||
role-to-assume: "arn:aws:iam::${{ env.ACCOUNT_NUMBER }}:role/github-actions" | ||
role-session-name: githubactionsrolesession | ||
aws-region: ${{ env.AWS_REGION }} | ||
- name: Load and Configure Terraform | ||
uses: hashicorp/setup-terraform@633666f66e0061ca3b725c73b2ec20cd13a8fdd1 # v2.0.3 | ||
with: | ||
terraform_version: "~1" | ||
terraform_wrapper: false | ||
- name: Plan - ${{ matrix.environment }} | ||
run: | | ||
terraform --version | ||
echo "Terraform plan - ${TF_ENV}" | ||
bash scripts/terraform-init.sh terraform/environments/$GITHUB_WORKFLOW | ||
terraform -chdir="terraform/environments/${GITHUB_WORKFLOW}" workspace select "${GITHUB_WORKFLOW}-${TF_ENV}" | ||
bash scripts/terraform-plan.sh terraform/environments/$GITHUB_WORKFLOW | ||
# These jobs run when creating a pull request | ||
deploy-dev-test: | ||
needs: plan-dev-test | ||
if: success() && github.event.inputs.action != 'destroy' | ||
strategy: | ||
matrix: | ||
include: | ||
- environment: development | ||
- environment: test | ||
name: Apply - ${{ matrix.environment }} | ||
runs-on: ubuntu-latest | ||
env: | ||
TF_ENV: ${{ matrix.environment }} | ||
environment: | ||
name: ${{ github.workflow }}-${{ matrix.environment }} | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3.0 | ||
- name: Set Account Number | ||
run: echo "ACCOUNT_NUMBER=$(jq -r -e --arg account_name "${GITHUB_WORKFLOW}-${TF_ENV}" '.account_ids[$account_name]' <<< $ENVIRONMENT_MANAGEMENT)" >> $GITHUB_ENV | ||
- name: configure aws credentials | ||
uses: aws-actions/configure-aws-credentials@67fbcbb121271f7775d2e7715933280b06314838 # v1.7.0 | ||
with: | ||
role-to-assume: "arn:aws:iam::${{ env.ACCOUNT_NUMBER }}:role/github-actions" | ||
role-session-name: githubactionsrolesession | ||
aws-region: ${{ env.AWS_REGION }} | ||
- name: Load and Configure Terraform | ||
uses: hashicorp/setup-terraform@633666f66e0061ca3b725c73b2ec20cd13a8fdd1 # v2.0.3 | ||
with: | ||
terraform_version: "~1" | ||
terraform_wrapper: false | ||
- name: Apply - ${{ matrix.environment }} | ||
run: | | ||
terraform --version | ||
echo "Terraform apply - ${TF_ENV}" | ||
bash scripts/terraform-init.sh terraform/environments/$GITHUB_WORKFLOW | ||
terraform -chdir="terraform/environments/${GITHUB_WORKFLOW}" workspace select "${GITHUB_WORKFLOW}-${TF_ENV}" | ||
bash scripts/terraform-apply.sh terraform/environments/$GITHUB_WORKFLOW | ||
destroy-plan-dev-test: | ||
strategy: | ||
matrix: | ||
include: | ||
- environment: development | ||
- environment: test | ||
name: Terraform destroy plan - ${{ github.workflow }} - ${{ matrix.environment }} | ||
runs-on: ubuntu-latest | ||
if: github.event_name == 'workflow_dispatch' && github.event.inputs.action == 'destroy' | ||
env: | ||
TF_ENV: ${{ matrix.environment }} | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3.0 | ||
- name: Set Account Number | ||
run: echo "ACCOUNT_NUMBER=$(jq -r -e --arg account_name "${GITHUB_WORKFLOW}-${TF_ENV}" '.account_ids[$account_name]' <<< $ENVIRONMENT_MANAGEMENT)" >> $GITHUB_ENV | ||
- name: configure aws credentials | ||
uses: aws-actions/configure-aws-credentials@67fbcbb121271f7775d2e7715933280b06314838 # v1.7.0 | ||
with: | ||
role-to-assume: "arn:aws:iam::${{ env.ACCOUNT_NUMBER }}:role/github-actions" | ||
role-session-name: githubactionsrolesession | ||
aws-region: ${{ env.AWS_REGION }} | ||
- name: Load and Configure Terraform | ||
uses: hashicorp/setup-terraform@633666f66e0061ca3b725c73b2ec20cd13a8fdd1 # v2.0.3 | ||
with: | ||
terraform_version: "~1" | ||
terraform_wrapper: false | ||
- name: Terraform destroy plan - ${{ github.workflow }} - ${{ matrix.environment }} | ||
run: | | ||
terraform --version | ||
echo "Terraform destroy plan - ${TF_ENV}" | ||
bash scripts/terraform-init.sh terraform/environments/$GITHUB_WORKFLOW | ||
terraform -chdir="terraform/environments/${GITHUB_WORKFLOW}" workspace select "${GITHUB_WORKFLOW}-${TF_ENV}" | ||
bash scripts/terraform-plan.sh terraform/environments/$GITHUB_WORKFLOW -destroy | ||
destroy-apply-dev-test: | ||
needs: destroy-plan-dev-test | ||
if: success() | ||
strategy: | ||
matrix: | ||
include: | ||
- environment: development | ||
- environment: test | ||
name: Terraform destroy apply - ${{ github.workflow }} - ${{ matrix.environment }} | ||
runs-on: ubuntu-latest | ||
env: | ||
TF_ENV: ${{ matrix.environment }} | ||
environment: | ||
name: ${{ github.workflow }}-${{ matrix.environment }} | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3.0 | ||
- name: Set Account Number | ||
run: echo "ACCOUNT_NUMBER=$(jq -r -e --arg account_name "${GITHUB_WORKFLOW}-${TF_ENV}" '.account_ids[$account_name]' <<< $ENVIRONMENT_MANAGEMENT)" >> $GITHUB_ENV | ||
- name: configure aws credentials | ||
uses: aws-actions/configure-aws-credentials@67fbcbb121271f7775d2e7715933280b06314838 # v1.7.0 | ||
with: | ||
role-to-assume: "arn:aws:iam::${{ env.ACCOUNT_NUMBER }}:role/github-actions" | ||
role-session-name: githubactionsrolesession | ||
aws-region: ${{ env.AWS_REGION }} | ||
- name: Load and Configure Terraform | ||
uses: hashicorp/setup-terraform@633666f66e0061ca3b725c73b2ec20cd13a8fdd1 # v2.0.3 | ||
with: | ||
terraform_version: "~1" | ||
terraform_wrapper: false | ||
- name: Terraform destroy apply - ${{ github.workflow }} - ${{ matrix.environment }} | ||
run: | | ||
terraform --version | ||
echo "Terraform destroy apply - ${TF_ENV}" | ||
bash scripts/terraform-init.sh terraform/environments/$GITHUB_WORKFLOW | ||
terraform -chdir="terraform/environments/${GITHUB_WORKFLOW}" workspace select "${GITHUB_WORKFLOW}-${TF_ENV}" | ||
bash scripts/terraform-apply.sh terraform/environments/$GITHUB_WORKFLOW -destroy | ||
# # Plan + deploy for pre-production and production environments, only from main | ||
plan-preprod-prod: | ||
strategy: | ||
matrix: | ||
include: | ||
- environment: preproduction | ||
- environment: production | ||
name: Plan - ${{ matrix.environment }} | ||
runs-on: ubuntu-latest | ||
if: github.ref == 'refs/heads/main' | ||
env: | ||
TF_ENV: ${{ matrix.environment }} | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3.0 | ||
- name: Set Account Number | ||
run: echo "ACCOUNT_NUMBER=$(jq -r -e --arg account_name "${GITHUB_WORKFLOW}-${TF_ENV}" '.account_ids[$account_name]' <<< $ENVIRONMENT_MANAGEMENT)" >> $GITHUB_ENV | ||
- name: configure aws credentials | ||
uses: aws-actions/configure-aws-credentials@67fbcbb121271f7775d2e7715933280b06314838 # v1.7.0 | ||
with: | ||
role-to-assume: "arn:aws:iam::${{ env.ACCOUNT_NUMBER }}:role/github-actions" | ||
role-session-name: githubactionsrolesession | ||
aws-region: ${{ env.AWS_REGION }} | ||
- name: Load and Configure Terraform | ||
uses: hashicorp/setup-terraform@633666f66e0061ca3b725c73b2ec20cd13a8fdd1 # v2.0.3 | ||
with: | ||
terraform_version: "~1" | ||
terraform_wrapper: false | ||
- name: Plan - ${{ matrix.environment }} | ||
run: | | ||
terraform --version | ||
echo "Terraform plan - ${TF_ENV}" | ||
bash scripts/terraform-init.sh terraform/environments/$GITHUB_WORKFLOW | ||
terraform -chdir="terraform/environments/${GITHUB_WORKFLOW}" workspace select "${GITHUB_WORKFLOW}-${TF_ENV}" | ||
bash scripts/terraform-plan.sh terraform/environments/$GITHUB_WORKFLOW | ||
# These jobs run when creating a pull request | ||
deploy-preprod-prod: | ||
needs: plan-preprod-prod | ||
if: success() | ||
strategy: | ||
matrix: | ||
include: | ||
- environment: preproduction | ||
- environment: production | ||
name: Apply - ${{ matrix.environment }} | ||
runs-on: ubuntu-latest | ||
env: | ||
TF_ENV: ${{ matrix.environment }} | ||
environment: | ||
name: ${{ github.workflow }}-${{ matrix.environment }} | ||
steps: | ||
- name: Checkout Repository | ||
uses: actions/checkout@ac593985615ec2ede58e132d2e21d2b1cbd6127c # v3.3.0 | ||
- name: Set Account Number | ||
run: echo "ACCOUNT_NUMBER=$(jq -r -e --arg account_name "${GITHUB_WORKFLOW}-${TF_ENV}" '.account_ids[$account_name]' <<< $ENVIRONMENT_MANAGEMENT)" >> $GITHUB_ENV | ||
- name: configure aws credentials | ||
uses: aws-actions/configure-aws-credentials@67fbcbb121271f7775d2e7715933280b06314838 # v1.7.0 | ||
with: | ||
role-to-assume: "arn:aws:iam::${{ env.ACCOUNT_NUMBER }}:role/github-actions" | ||
role-session-name: githubactionsrolesession | ||
aws-region: ${{ env.AWS_REGION }} | ||
- name: Load and Configure Terraform | ||
uses: hashicorp/setup-terraform@633666f66e0061ca3b725c73b2ec20cd13a8fdd1 # v2.0.3 | ||
with: | ||
terraform_version: "~1" | ||
terraform_wrapper: false | ||
- name: Apply - ${{ matrix.environment }} | ||
run: | | ||
terraform --version | ||
echo "Terraform apply - ${TF_ENV}" | ||
bash scripts/terraform-init.sh terraform/environments/$GITHUB_WORKFLOW | ||
terraform -chdir="terraform/environments/${GITHUB_WORKFLOW}" workspace select "${GITHUB_WORKFLOW}-${TF_ENV}" | ||
bash scripts/terraform-apply.sh terraform/environments/$GITHUB_WORKFLOW |
76 changes: 76 additions & 0 deletions
76
terraform/environments/hmpps-intelligence-management/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
# Service Runbook | ||
|
||
<!-- This is a template that should be populated by the development team when moving to the modernisation platform, but also reviewed and kept up to date. | ||
To ensure that people looking at your runbook can get the information they need quickly, your runbook should be short but clear. Throughout, only use acronyms if you’re confident that someone who has just been woken up at 3am would understand them. --> | ||
|
||
_If you have any questions surrounding this page please post in the `#team-name` channel._ | ||
|
||
## Mandatory Information | ||
|
||
### **Last review date:** | ||
|
||
<!-- Adding the last date this page was reviewed, with any accompanying information --> | ||
|
||
### **Description:** | ||
|
||
<!-- A short (less than 50 word) description of what your service does, and who it’s for.--> | ||
|
||
### **Service URLs:** | ||
|
||
<!-- The URL(s) of the service’s production environment, and test environments if possible--> | ||
|
||
### **Incident response hours:** | ||
|
||
<!-- When your service receives support for urgent issues. This should be written in a clear, unambiguous way. For example: 24/7/365, Office hours, usually 9am-6pm on working days, or 7am-10pm, 365 days a year. --> | ||
|
||
### **Incident contact details:** | ||
|
||
<!-- How people can raise an urgent issue with your service. This must not be the email address or phone number of an individual on your team, it should be a shared email address, phone number, or website that allows someone with an urgent issue to raise it quickly. --> | ||
|
||
### **Service team contact:** | ||
|
||
<!-- How people with non-urgent issues or questions can get in touch with your team. As with incident contact details, this must not be the email address or phone number of an individual on the team, it should be a shared email address or a ticket tracking system.--> | ||
|
||
### **Hosting environment:** | ||
|
||
Modernisation Platform | ||
|
||
<!-- If your service is hosted on another MOJ team’s infrastructure, link to their runbook. If your service has another arrangement or runs its own infrastructure, you should list the supplier of that infrastructure (ideally linking to your account’s login page) and describe, simply and briefly, how to raise an issue with them. --> | ||
|
||
## Optional | ||
|
||
### **Other URLs:** | ||
|
||
<!-- If you can, provide links to the service’s monitoring dashboard(s), health checks, documentation (ideally describing how to run/work with the service), and main GitHub repository. --> | ||
|
||
### **Expected speed and frequency of releases:** | ||
|
||
<!-- How often are you able to release changes to your service, and how long do those changes take? --> | ||
|
||
### **Automatic alerts:** | ||
|
||
<!-- List, briefly, problems (or types of problem) that will automatically alert your team when they occur. --> | ||
|
||
### **Impact of an outage:** | ||
|
||
<!-- A short description of the risks if your service is down for an extended period of time. --> | ||
|
||
### **Out of hours response types:** | ||
|
||
<!-- Describe how incidents that page a person on call are responded to. How long are out-of-hours responders expected to spend trying to resolve issues before they stop working, put the service into maintenance mode, and hand the issue to in-hours support? --> | ||
|
||
### **Consumers of this service:** | ||
|
||
<!-- List which other services (with links to their runbooks) rely on this service. If your service is considered a platform, these may be too numerous to reasonably list. --> | ||
|
||
### **Services consumed by this:** | ||
|
||
<!-- List which other services (with links to their runbooks) this service relies on. --> | ||
|
||
### **Restrictions on access:** | ||
|
||
<!-- Describe any conditions which restrict access to the service, such as if it’s IP-restricted or only accessible from a private network.--> | ||
|
||
### **How to resolve specific issues:** | ||
|
||
<!-- Describe the steps someone might take to resolve a specific issue or incident, often for use when on call. This may be a large amount of information, so may need to be split out into multiple pages, or link to other documents.--> |
16 changes: 16 additions & 0 deletions
16
terraform/environments/hmpps-intelligence-management/application_variables.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
{ | ||
"accounts": { | ||
"development": { | ||
"example_var": "dev-data" | ||
}, | ||
"test": { | ||
"example_var": "test-data" | ||
}, | ||
"preproduction": { | ||
"example_var": "preproduction-data" | ||
}, | ||
"production": { | ||
"example_var": "production-data" | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
#### This file can be used to store data specific to the member account #### |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
#### This file can be used to store locals specific to the member account #### |
9 changes: 9 additions & 0 deletions
9
terraform/environments/hmpps-intelligence-management/networking.auto.tfvars.json
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
{ | ||
"networking": [ | ||
{ | ||
"business-unit": "", | ||
"set": "", | ||
"application": "hmpps-intelligence-management" | ||
} | ||
] | ||
} |
13 changes: 13 additions & 0 deletions
13
terraform/environments/hmpps-intelligence-management/platform_backend.tf
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# Backend | ||
terraform { | ||
# `backend` blocks do not support variables, so the following are hard-coded here: | ||
# - S3 bucket name, which is created in modernisation-platform-account/s3.tf | ||
backend "s3" { | ||
acl = "bucket-owner-full-control" | ||
bucket = "modernisation-platform-terraform-state" | ||
encrypt = true | ||
key = "terraform.tfstate" | ||
region = "eu-west-2" | ||
workspace_key_prefix = "environments/members/hmpps-intelligence-management" # This will store the object as environments/members/hmpps-intelligence-management/${workspace}/terraform.tfstate | ||
} | ||
} |
Oops, something went wrong.