Skip to content

Commit

Permalink
Workflow: created files in .
Browse files Browse the repository at this point in the history
  • Loading branch information
modernisation-platform-ci committed Feb 23, 2023
1 parent 5c3855e commit 00428a3
Show file tree
Hide file tree
Showing 38 changed files with 647 additions and 23 deletions.
1 change: 1 addition & 0 deletions .github/CODEOWNERS
Validating CODEOWNERS rules …
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
/terraform/environments/long-term-storage @ministryofjustice/modernisation-platform @ministryofjustice/modernisation-platform
/terraform/environments/maatdb @ministryofjustice/laa-aws-infrastructure @ministryofjustice/modernisation-platform
/terraform/environments/mlra @ministryofjustice/laa-aws-infrastructure @ministryofjustice/modernisation-platform
/terraform/environments/nomis-combined-reporting @ministryofjustice/studio-webops @ministryofjustice/modernisation-platform
/terraform/environments/nomis @ministryofjustice/studio-webops @ministryofjustice/modernisation-platform
/terraform/environments/oas @ministryofjustice/laa-aws-infrastructure @ministryofjustice/modernisation-platform
/terraform/environments/oasys @ministryofjustice/studio-webops @ministryofjustice/modernisation-platform
Expand Down
177 changes: 177 additions & 0 deletions .github/workflows/nomis-combined-reporting.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,177 @@
---
name: nomis-combined-reporting
on:
push:
branches:
- main
paths:
- 'terraform/environments/nomis-combined-reporting/**'
- '.github/workflows/nomis-combined-reporting.yml'
pull_request:
branches:
- main
types: [opened, edited, reopened, synchronize]
paths:
- 'terraform/environments/nomis-combined-reporting/**'
- '.github/workflows/nomis-combined-reporting.yml'
workflow_dispatch:
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'
env:
TF_ENV: ${{ matrix.environment }}
steps:
- name: Checkout Repository
uses: actions/checkout@93ea575cb5d8a053eaa0ac8fa3b40d7e05a33cc8 # v3.1.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()
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@93ea575cb5d8a053eaa0ac8fa3b40d7e05a33cc8 # v3.1.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
# # 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@93ea575cb5d8a053eaa0ac8fa3b40d7e05a33cc8 # v3.1.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@93ea575cb5d8a053eaa0ac8fa3b40d7e05a33cc8 # v3.1.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
2 changes: 1 addition & 1 deletion terraform/environments/apex/networking.auto.tfvars.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "laa",
"business-unit": "core",
"set": "general",
"application": "apex"
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "laa",
"business-unit": "core",
"set": "general",
"application": "ccms-ebs"
}
Expand Down
2 changes: 1 addition & 1 deletion terraform/environments/cooker/networking.auto.tfvars.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "house",
"business-unit": "core",
"set": "general",
"application": "cooker"
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "hq",
"business-unit": "core",
"set": "general",
"application": "data-and-insights-wepi"
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "hmpps",
"business-unit": "core",
"set": "general",
"application": "delius-iaps"
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "hmpps",
"business-unit": "core",
"set": "general",
"application": "delius-jitbit"
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "hmpps",
"business-unit": "core",
"set": "general",
"application": "digital-prison-reporting"
}
Expand Down
2 changes: 1 addition & 1 deletion terraform/environments/equip/networking.auto.tfvars.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "hmpps",
"business-unit": "core",
"set": "general",
"application": "equip"
}
Expand Down
2 changes: 1 addition & 1 deletion terraform/environments/example/networking.auto.tfvars.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "platforms",
"business-unit": "core",
"set": "general",
"application": "example"
}
Expand Down
2 changes: 1 addition & 1 deletion terraform/environments/laa-oem/networking.auto.tfvars.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "laa",
"business-unit": "core",
"set": "general",
"application": "laa-oem"
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "platforms",
"business-unit": "core",
"set": "general",
"application": "long-term-storage"
}
Expand Down
2 changes: 1 addition & 1 deletion terraform/environments/maatdb/networking.auto.tfvars.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "laa",
"business-unit": "core",
"set": "general",
"application": "maatdb"
}
Expand Down
2 changes: 1 addition & 1 deletion terraform/environments/mlra/networking.auto.tfvars.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"networking": [
{
"business-unit": "laa",
"business-unit": "core",
"set": "general",
"application": "mlra"
}
Expand Down
76 changes: 76 additions & 0 deletions terraform/environments/nomis-combined-reporting/README.md
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.-->
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"
}
}
}
1 change: 1 addition & 0 deletions terraform/environments/nomis-combined-reporting/data.tf
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 ####
Loading

0 comments on commit 00428a3

Please sign in to comment.