2022-03-07 12:01:40 +01:00
|
|
|
# You can override the included template(s) by including variable overrides
|
|
|
|
# SAST customization: https://docs.gitlab.com/ee/user/application_security/sast/#customizing-the-sast-settings
|
|
|
|
# Secret Detection customization: https://docs.gitlab.com/ee/user/application_security/secret_detection/#customizing-settings
|
|
|
|
# Dependency Scanning customization: https://docs.gitlab.com/ee/user/application_security/dependency_scanning/#customizing-the-dependency-scanning-settings
|
|
|
|
# Container Scanning customization: https://docs.gitlab.com/ee/user/application_security/container_scanning/#customizing-the-container-scanning-settings
|
|
|
|
# Note that environment variables can be set in several places
|
|
|
|
# See https://docs.gitlab.com/ee/ci/variables/#cicd-variable-precedence
|
2022-03-07 11:49:45 +01:00
|
|
|
|
2022-03-07 12:01:40 +01:00
|
|
|
# container_scanning:
|
|
|
|
# variables:
|
|
|
|
# DOCKER_IMAGE: ...
|
|
|
|
# DOCKER_USER: ...
|
|
|
|
# DOCKER_PASSWORD: ...
|
|
|
|
stages:
|
|
|
|
- build
|
|
|
|
- test
|
|
|
|
- deploy
|
2022-03-06 11:32:29 +01:00
|
|
|
image: debian
|
2022-03-06 12:02:30 +01:00
|
|
|
docker-build-push:
|
2022-03-06 05:08:40 +01:00
|
|
|
image: docker:latest
|
|
|
|
stage: build
|
|
|
|
services:
|
2022-03-07 12:01:40 +01:00
|
|
|
- docker:dind
|
2022-03-06 05:08:40 +01:00
|
|
|
before_script:
|
2022-03-07 12:01:40 +01:00
|
|
|
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
|
2022-03-06 05:08:40 +01:00
|
|
|
script:
|
2022-03-07 12:01:40 +01:00
|
|
|
- |
|
|
|
|
if [[ "$CI_COMMIT_BRANCH" == "$CI_DEFAULT_BRANCH" ]]; then
|
|
|
|
tag=""
|
|
|
|
echo "Running on default branch '$CI_DEFAULT_BRANCH': tag = 'latest'"
|
|
|
|
else
|
|
|
|
tag=":$CI_COMMIT_REF_SLUG"
|
|
|
|
echo "Running on branch '$CI_COMMIT_BRANCH': tag = $tag"
|
|
|
|
fi
|
|
|
|
- docker build --pull -t "$CI_REGISTRY_IMAGE${tag}" .
|
|
|
|
- docker push "$CI_REGISTRY_IMAGE${tag}"
|
2022-03-06 11:36:37 +01:00
|
|
|
only:
|
2022-03-07 12:01:40 +01:00
|
|
|
- master
|
|
|
|
- dev
|
2022-03-06 12:02:30 +01:00
|
|
|
docker-build:
|
|
|
|
image: docker:latest
|
|
|
|
stage: build
|
|
|
|
services:
|
2022-03-07 12:01:40 +01:00
|
|
|
- docker:dind
|
2022-03-06 12:02:30 +01:00
|
|
|
before_script:
|
2022-03-07 12:01:40 +01:00
|
|
|
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
|
2022-03-06 12:02:30 +01:00
|
|
|
script:
|
2022-03-07 12:01:40 +01:00
|
|
|
- docker build --pull -t "$CI_REGISTRY_IMAGE" .
|
2022-03-06 12:02:30 +01:00
|
|
|
except:
|
2022-03-07 12:01:40 +01:00
|
|
|
- master
|
|
|
|
- dev
|
2022-03-06 11:32:29 +01:00
|
|
|
before_script:
|
2022-03-07 12:01:40 +01:00
|
|
|
- apt-get update -qq
|
|
|
|
- which ssh-agent || ( apt-get install -qq openssh-client )
|
|
|
|
- eval $(ssh-agent -s)
|
|
|
|
- ssh-add <(echo "$SSH_PRIVATE_KEY")
|
|
|
|
- mkdir -p ~/.ssh
|
|
|
|
- '[[ -f /.dockerenv ]] && echo -e "Host *\n\tStrictHostKeyChecking no\n\n" > ~/.ssh/config'
|
2022-03-06 11:32:29 +01:00
|
|
|
deploy_staging:
|
2022-03-06 11:42:50 +01:00
|
|
|
stage: deploy
|
2022-03-06 11:32:29 +01:00
|
|
|
script:
|
2022-03-07 12:01:40 +01:00
|
|
|
- ssh $SSH_SERVER "cd /root && docker-compose pull shbot && docker-compose up -d
|
|
|
|
shbot && exit"
|
2022-03-06 11:32:29 +01:00
|
|
|
only:
|
2022-03-07 12:01:40 +01:00
|
|
|
- master
|
|
|
|
include:
|
|
|
|
- template: Auto-DevOps.gitlab-ci.yml
|