-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path.gitlab-ci.yml
63 lines (59 loc) · 3.51 KB
/
.gitlab-ci.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
stages:
- build
- deploy
services:
- dind
build-client:
stage: build
image: docker
script:
- docker info
- if [ ! -z "$CI_COMMIT_TAG" ]; then COMMON_TAG="release"; elif [ "$CI_COMMIT_REF_NAME" == "master" ]; then COMMON_TAG="latest"; else COMMON_TAG=$CI_COMMIT_REF_SLUG; fi
- if [ ! -z "$CI_COMMIT_TAG" ]; then IMAGE_IDENTIFIER="$CI_COMMIT_TAG"; else IMAGE_IDENTIFIER=$CI_COMMIT_SHA; fi
- cd client && docker build -t "$CI_REGISTRY_IMAGE:$IMAGE_IDENTIFIER" -t "$CI_REGISTRY_IMAGE:$COMMON_TAG" .
- echo $CI_REGISTRY_PASSWORD | docker login --username $CI_REGISTRY_USER $CI_REGISTRY --password-stdin
- docker push $CI_REGISTRY_IMAGE:$IMAGE_IDENTIFIER
- docker push $CI_REGISTRY_IMAGE:$COMMON_TAG
build-api:
stage: build
image: docker
script:
- docker info
- if [ ! -z "$CI_COMMIT_TAG" ]; then COMMON_TAG="release"; elif [ "$CI_COMMIT_REF_NAME" == "master" ]; then COMMON_TAG="latest"; else COMMON_TAG=$CI_COMMIT_REF_SLUG; fi
- if [ ! -z "$CI_COMMIT_TAG" ]; then IMAGE_IDENTIFIER="$CI_COMMIT_TAG"; else IMAGE_IDENTIFIER=$CI_COMMIT_SHA; fi
- cd api && docker build -t "$CI_REGISTRY_IMAGE:api-$IMAGE_IDENTIFIER" -t "$CI_REGISTRY_IMAGE:api-$COMMON_TAG" .
- echo $CI_REGISTRY_PASSWORD | docker login --username $CI_REGISTRY_USER $CI_REGISTRY --password-stdin
- docker push $CI_REGISTRY_IMAGE:api-$IMAGE_IDENTIFIER
- docker push $CI_REGISTRY_IMAGE:api-$COMMON_TAG
build-server:
stage: build
image: docker
script:
- docker info
- if [ ! -z "$CI_COMMIT_TAG" ]; then COMMON_TAG="release"; elif [ "$CI_COMMIT_REF_NAME" == "master" ]; then COMMON_TAG="latest"; else COMMON_TAG=$CI_COMMIT_REF_SLUG; fi
- if [ ! -z "$CI_COMMIT_TAG" ]; then IMAGE_IDENTIFIER="$CI_COMMIT_TAG"; else IMAGE_IDENTIFIER=$CI_COMMIT_SHA; fi
- cd server && docker build -t "$CI_REGISTRY_IMAGE:server-$IMAGE_IDENTIFIER" -t "$CI_REGISTRY_IMAGE:server-$COMMON_TAG" .
- echo $CI_REGISTRY_PASSWORD | docker login --username $CI_REGISTRY_USER $CI_REGISTRY --password-stdin
- docker push "$CI_REGISTRY_IMAGE:server-$IMAGE_IDENTIFIER"
- docker push "$CI_REGISTRY_IMAGE:server-$COMMON_TAG"
deploy-dev:
stage: deploy
image: docker:latest
only:
refs:
- develop
script:
- echo $CI_REGISTRY_PASSWORD | docker login --username $CI_REGISTRY_USER $CI_REGISTRY --password-stdin
- docker --host 172.31.0.6:2376 service update --with-registry-auth --image $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA mempool_dev_webapp
- docker --host 172.31.0.6:2376 service update --with-registry-auth --image $CI_REGISTRY_IMAGE:api-$CI_COMMIT_SHA mempool_dev_api
# - docker --host 172.31.0.6:2376 service update --with-registry-auth --image $CI_REGISTRY_IMAGE:server-$CI_COMMIT_SHA mempool_explorer_websocket
deploy-release:
stage: deploy
image: docker:latest
only:
- tags
script:
- echo $CI_REGISTRY_PASSWORD | docker login --username $CI_REGISTRY_USER $CI_REGISTRY --password-stdin
- docker --host 172.31.0.7:2376 service update --with-registry-auth --image $CI_REGISTRY_IMAGE:$CI_COMMIT_TAG cardanoapi_mempool-explorer-webapp
- docker --host 172.31.0.7:2376 service update --with-registry-auth --image $CI_REGISTRY_IMAGE:api-$CI_COMMIT_TAG cardanoapi_mempool-explorer-api
- docker --host 172.31.0.7:2376 service update --with-registry-auth --image ${CI_REGISTRY_IMAGE}:server-${CI_COMMIT_TAG} cardanoapi_mempool-websocket