-
Notifications
You must be signed in to change notification settings - Fork 11
70 lines (67 loc) · 2.01 KB
/
push-monitor.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
name: Push Monitor
on:
# UI provided by Github, values populated by repository
workflow_dispatch:
inputs:
deployment-env:
description: "Environment to deploy to"
required: true
type: environment
# Invoked via another workflow, value passed in by string
workflow_call:
inputs:
deployment-env:
description: "Environment to deploy to"
required: true
type: string
secrets:
aws-role-arn:
required: true
description: "AWS_ROLE_ARN value"
aws-account-id:
required: true
description: "TID_AWS_ACCOUNT_ID value"
concurrency:
group: deploy-monitor-${{ inputs.deployment-env }}
cancel-in-progress: true
jobs:
check:
name: Check for changes in monitoring setup
runs-on: ubuntu-latest
outputs:
changed: ${{ steps.changes.outputs.monitor == 'true' }}
steps:
- name: Checkout
uses: actions/checkout@v4
- uses: dorny/paths-filter@v3
id: changes
with:
filters: |
monitor:
- 'deploy/monitor/**'
- 'integration/**'
push:
name: Deploy new version
runs-on: ubuntu-latest
needs: check
if: ${{ needs.check.outputs.changed }}
permissions:
id-token: write
contents: read
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Build, tag, and push image to Amazon ECR
id: ecr
uses: mbta/actions/build-push-ecr@v2
with:
docker-repo: "${{ secrets.aws-account-id }}.dkr.ecr.us-east-1.amazonaws.com/dotcom-monitor"
dockerfile-path: "-f ./deploy/monitor/Dockerfile ."
role-to-assume: ${{ secrets.aws-role-arn }}
- name: Deploy Monitor to ${{ inputs.deployment-env }}
uses: mbta/actions/deploy-ecs@v2
with:
role-to-assume: ${{ secrets.aws-role-arn }}
ecs-cluster: dotcom
ecs-service: dotcom-monitor-${{ inputs.deployment-env }}
docker-tag: ${{ steps.ecr.outputs.docker-tag }}