From 3f106cb44c1ffcd6223ddf79c43f4fa3170fe10b Mon Sep 17 00:00:00 2001 From: Tom Withers Date: Mon, 11 Jan 2021 15:05:44 +0000 Subject: [PATCH] Auto deploy tag from parameter store (#67) --- .github/workflows/build_containers.yml | 22 ++++++++++++++++++++++ .github/workflows/deploy.yml | 25 +++++++++++++++++++++++++ 2 files changed, 47 insertions(+) diff --git a/.github/workflows/build_containers.yml b/.github/workflows/build_containers.yml index ea11cc6..22b72f3 100644 --- a/.github/workflows/build_containers.yml +++ b/.github/workflows/build_containers.yml @@ -94,3 +94,25 @@ jobs: release_name: ${{ steps.create_tag.outputs.new_tag }} draft: false prerelease: false + + push_to_parameter_store: + name: Store Tag in Parameter Store + needs: build + runs-on: ubuntu-latest + if: github.ref == 'refs/heads/main' && github.event_name == 'push' + steps: + - name: Configure AWS Credentials + uses: aws-actions/configure-aws-credentials@v1 + with: + aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} + aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + aws-region: eu-west-1 + role-to-assume: arn:aws:iam::997462338508:role/shared-ci + role-duration-seconds: 3600 + role-session-name: GitHubActions + - name: Install AWS CLI + id: install-aws-cli + uses: unfor19/install-aws-cli-action@v1 + - name: Push Tag to Parameter Store + run: | + aws ssm put-parameter --name "incident-response-production-tag" --type "String" --value "${{needs.build.outputs.tag}}" --overwrite --region=eu-west-1 \ No newline at end of file diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index ebfe7ce..2242f02 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -11,6 +11,28 @@ defaults: shell: bash jobs: + pull_tag: + name: Pull latest tag from parameter store. + needs: build + runs-on: ubuntu-latest + if: github.ref == 'refs/heads/main' && github.event_name == 'push' + steps: + - name: Configure AWS Credentials + uses: aws-actions/configure-aws-credentials@v1 + with: + aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} + aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} + aws-region: eu-west-1 + role-to-assume: arn:aws:iam::997462338508:role/shared-ci + role-duration-seconds: 3600 + role-session-name: GitHubActions + - name: Install AWS CLI + id: install-aws-cli + uses: unfor19/install-aws-cli-action@v1 + - name: Pull Tag from Parameter Store + run: | + echo ::set-env name=TAG_NAME::$(aws ssm get-parameter --region "eu-west-1" --name "incident-response-production-tag" --query Parameter.Value) + terraform: name: 'Terraform' runs-on: ubuntu-latest @@ -18,6 +40,9 @@ jobs: AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} TF_WORKSPACE: production + with: + TF_VAR_response_tag: ${{ steps.pull_tag.outputs.TAG_NAME }} + TF_VAR_nginx_tag: ${{ steps.pull_tag.outputs.TAG_NAME }} steps: - name: Checkout