-
Notifications
You must be signed in to change notification settings - Fork 0
50 lines (41 loc) · 1.33 KB
/
CD.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
name: CD
on:
push:
branches: [ "dev" ]
pull_request:
branches: [ "dev" ]
types: [closed]
workflow_dispatch:
permissions:
contents: read
id-token: write
jobs:
deploy:
if: github.event.pull_request.merged == true
runs-on: self-hosted
steps:
- uses: actions/checkout@v4
- name: Docker Login
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_PASSWORD }}
- name: Pull Docker Image
run: sudo docker pull ${{ secrets.DOCKERHUB_USERNAME }}/orange
- name: AWS credential
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ secrets.AWS_ROLE_NAME }}
role-session-name: GithubActions
aws-region: ${{ secrets.SSM_PARAMETER_REGION }}
- name: Get Parameter
id: get-parameter
run: |
sudo aws ssm get-parameter --name ${{ secrets.SSM_PARAMETER_NAME }} --with-decryption --region ${{ secrets.SSM_PARAMETER_REGION }} --query "Parameter.Value" --output text > .env
- name: Deploy with Docker Compose
run: |
cd infra
sudo docker-compose --env-file ../.env down
sudo docker-compose --env-file ../.env up -d
rm -f ../.env
sudo docker image prune -f