-
Notifications
You must be signed in to change notification settings - Fork 4
70 lines (64 loc) · 2.3 KB
/
scheduled-update-demo.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: "[Scheduled] Keep demo environment up to date"
on:
schedule:
# Every 8am
- cron: '0 8 * * *'
permissions:
contents: read
security-events: none
pull-requests: none
actions: none
checks: none
deployments: none
issues: none
packages: none
repository-projects: none
statuses: none
jobs:
terraform_apply_environment:
name: terraform apply demo environment
uses: ./.github/workflows/_run-terraform.yml
with:
workspace: demo
terraform_path: environment
apply: true
specific_path: terraform
secrets: inherit
seed_dynamodb:
name: seed dynamodb
uses: ./.github/workflows/_seed-database.yml
needs:
- terraform_apply_environment
secrets: inherit
force_redeployment:
name: force redeployment
runs-on: ubuntu-latest
needs:
- terraform_apply_environment
- seed_dynamodb
steps:
- name: configure AWS credentials for ecs update
uses: aws-actions/configure-aws-credentials@375a690dc0af3921541e5f427167f333d7e85f67 # [email protected]
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID_ACTIONS }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY_ACTIONS }}
role-to-assume: arn:aws:iam::367815980639:role/opg-use-an-lpa-ci
aws-region: eu-west-1
role-duration-seconds: 1800
role-session-name: OPGUseAnLPADevAssumeGithubAction
- name: force new deployment
run: |
aws ecs update-service --cluster demo-use-an-lpa --force-new-deployment --service api-service --region eu-west-1
aws ecs update-service --cluster demo-use-an-lpa --force-new-deployment --service pdf-service --region eu-west-1
aws ecs update-service --cluster demo-use-an-lpa --force-new-deployment --service actor-service --region eu-west-1
aws ecs update-service --cluster demo-use-an-lpa --force-new-deployment --service viewer-service --region eu-west-1
aws ecs update-service --cluster demo-use-an-lpa --force-new-deployment --service admin-service --region eu-west-1
slack_notify:
name: notify of result
uses: ./.github/workflows/_slack-notification.yml
needs:
- force_redeployment
with:
template: successful_demo_release.txt
secrets:
webhook: ${{ secrets.DEV_SLACK_WEB_HOOK }}