-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-ecr.yml
More file actions
53 lines (48 loc) · 1.19 KB
/
docker-ecr.yml
File metadata and controls
53 lines (48 loc) · 1.19 KB
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
stages:
- deploy_dev
- deploy_prod
.aws_prod:
variables:
AWS_ACCESS_KEY_ID: $AWS_ACCESS_KEY_ID_prod
AWS_SECRET_ACCESS_KEY: $AWS_SECRET_ACCESS_KEY_prod
.aws_dev:
variables:
AWS_ACCESS_KEY_ID: $AWS_ACCESS_KEY_ID_dev
AWS_SECRET_ACCESS_KEY: $AWS_SECRET_ACCESS_KEY_dev
.deploy_ecr:
image: docker:latest
stage: build
services:
- docker:dind
script:
- apk add --no-cache python py-pip
- pip install awscli
- aws ecr get-login-password --region $ECR_REGION | docker login --username AWS --password-stdin $ECR_REPOSITORY
- docker build $ECR_REPOSITORY/$ECR_IMAGE:latest .
- docker push $ECR_REPOSITORY/$ECR_IMAGE:latest
deploy_docker_dev:
stage: deploy_dev
extends:
- .aws_dev
- .deploy_ecr
variables:
ECR_REPOSITORY: $ECR_REPOSITORY_dev
environment:
name: development
only:
- master
deploy_docker_prod:
stage: deploy_prod
extends:
- .aws_dev
- .deploy_ecr
variables:
ECR_REPOSITORY: $ECR_REPOSITORY_prod
environment:
name: production
dependencies:
- deploy_docker_dev
rules:
- if: '$CI_PIPELINE_SOURCE == "merge_request_event" && $CI_COMMIT_BRANCH == "master"'
when: manual
- when: never