211 lines
7.6 KiB
YAML
211 lines
7.6 KiB
YAML
---
|
|
image: mcr.microsoft.com/dotnet/core/sdk:3.0-alpine3.11
|
|
|
|
|
|
variables:
|
|
GIT_SUBMODULE_STRATEGY: recursive
|
|
OBJECTS_DIRECTORY: 'obj'
|
|
NUGET_PACKAGES_DIRECTORY: '.nuget'
|
|
SOURCE_CODE_PATH: 'ChaosBot/'
|
|
NODE_MODULES_DIRECTORY: 'wwwroot/node_modules'
|
|
|
|
stages:
|
|
- "Build Code"
|
|
- "Test Code"
|
|
- "Compile Release"
|
|
- "Get Next Version"
|
|
- "Build Docker Image"
|
|
- "Pull Image on Production"
|
|
|
|
cache:
|
|
key: "$CI_JOB_STAGE-$CI_COMMIT_REF_SLUG"
|
|
paths:
|
|
# Specify three paths that should be cached:
|
|
#
|
|
# 1) Main JSON file holding information about package dependency tree, packages versions,
|
|
# frameworks etc. It also holds information where to the dependencies were restored.
|
|
- '$SOURCE_CODE_PATH$OBJECTS_DIRECTORY/project.assets.json'
|
|
# 2) Other NuGet and MSBuild related files. Also needed.
|
|
- '$SOURCE_CODE_PATH$OBJECTS_DIRECTORY/*.csproj.nuget.*'
|
|
# 3) Path to the directory where restored dependencies are kept.
|
|
- '$NUGET_PACKAGES_DIRECTORY'
|
|
# 4) Path to node_modules
|
|
- '$SOURCE_CODE_PATH$NODE_MODULES_DIRECTORY'
|
|
#
|
|
policy: pull-push
|
|
|
|
"Build dotnet":
|
|
stage: "Build Code"
|
|
only:
|
|
changes:
|
|
- ChaosBot/**/*
|
|
refs:
|
|
- master
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
script:
|
|
- 'dotnet restore --packages $NUGET_PACKAGES_DIRECTORY'
|
|
- 'dotnet build --no-restore'
|
|
|
|
"Test dotnet":
|
|
stage: "Test Code"
|
|
only:
|
|
changes:
|
|
- ChaosBot/**/*
|
|
refs:
|
|
- master
|
|
dependencies:
|
|
- "Build dotnet"
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
script:
|
|
- 'dotnet restore --packages $NUGET_PACKAGES_DIRECTORY'
|
|
- 'dotnet test --no-restore'
|
|
|
|
"Build node":
|
|
image: node:latest
|
|
stage: "Build Code"
|
|
only:
|
|
changes:
|
|
- ChaosBot/wwwroot/*
|
|
refs:
|
|
- master
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
script:
|
|
- 'cd ChaosBot/wwwroot'
|
|
- 'yarn install'
|
|
- 'yarn build'
|
|
artifacts:
|
|
paths:
|
|
- ChaosBot/wwwroot/dist/*
|
|
|
|
"Test node":
|
|
image: node:latest
|
|
stage: "Test Code"
|
|
only:
|
|
changes:
|
|
- ChaosBot/wwwroot/*
|
|
refs:
|
|
- master
|
|
dependencies:
|
|
- "Build node"
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
script:
|
|
- 'cd ChaosBot/wwwroot'
|
|
- 'yarn install'
|
|
- 'yarn lint'
|
|
|
|
"Compile release":
|
|
stage: "Compile Release"
|
|
only:
|
|
changes:
|
|
- ChaosBot/**/*
|
|
refs:
|
|
- master
|
|
dependencies:
|
|
- "Test dotnet"
|
|
- "Build node"
|
|
- "Test node"
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
script:
|
|
- 'dotnet restore --packages $NUGET_PACKAGES_DIRECTORY'
|
|
- 'dotnet publish -c Release --runtime linux-musl-x64 -o build -p:PublishSingleFile=true ChaosBot'
|
|
artifacts:
|
|
paths:
|
|
- build/*
|
|
|
|
"Get next version":
|
|
stage: "Get Next Version"
|
|
only:
|
|
changes:
|
|
- ChaosBot/**/*
|
|
refs:
|
|
- master
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
script:
|
|
- 'apk add git grep npm openssh-client'
|
|
- 'npm install -g semver'
|
|
- 'mkdir -p ~/.ssh/'
|
|
- 'echo -e $GITLAB_DEPLOY_KEY > ~/.ssh/id_rsa'
|
|
- 'chmod 600 ~/.ssh/id_rsa'
|
|
- 'ssh-keyscan -p 2302 git.chaoticlogic.us >> ~/.ssh/known_hosts'
|
|
- 'git tag $(semver -i $( (git log -1 --pretty=%B | grep -oP "(?<=#)(patch|minor|major)" || echo "patch") | head -1) $(git tag --list | sort -rV | head -1))'
|
|
- 'git config remote.deploy.url >&- || git remote add deploy ssh://git@git.chaoticlogic.us:2302/discord-bots/chaosbot.git'
|
|
- 'git push deploy --tags'
|
|
- 'git describe --tags | tr -d "\n" > version'
|
|
artifacts:
|
|
paths:
|
|
- version
|
|
|
|
"Build docker image":
|
|
image: docker:stable
|
|
stage: "Build Docker Image"
|
|
only:
|
|
changes:
|
|
- ChaosBot/**/*
|
|
refs:
|
|
- master
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
dependencies:
|
|
- "Get next version"
|
|
- "Compile release"
|
|
script:
|
|
# Log in to the registry
|
|
- 'docker login -u=$REGISTRY_USER -p=$REGISTRY_PASS registry.chaoticlogic.us'
|
|
# Build the image
|
|
- 'docker -H unix:///var/run/docker.sock image build -t chaosbot:`cat version` ./'
|
|
# Tag the image with a registry tag
|
|
- 'docker -H unix:///var/run/docker.sock image tag chaosbot:`cat version` registry.chaoticlogic.us/chaosbot:`cat version`'
|
|
- 'docker -H unix:///var/run/docker.sock image tag chaosbot:`cat version` registry.chaoticlogic.us/chaosbot:latest'
|
|
# Push the registry images
|
|
- 'docker -H unix:///var/run/docker.sock image push registry.chaoticlogic.us/chaosbot:`cat version`'
|
|
- 'docker -H unix:///var/run/docker.sock image push registry.chaoticlogic.us/chaosbot:latest'
|
|
|
|
|
|
"Pull image on production":
|
|
stage: "Pull Image on Production"
|
|
only:
|
|
changes:
|
|
- ChaosBot/**/*
|
|
refs:
|
|
- master
|
|
tags:
|
|
- docker
|
|
- hawkeye
|
|
dependencies:
|
|
- "Build docker image"
|
|
script:
|
|
- 'apk add curl jq'
|
|
# Sign in with credentials
|
|
- 'AUTH_TOKEN="`curl -X POST $API_URI/api/auth -H "Content-Type: application/json" -d "{\\"Username\\": \\"$API_USER\\", \\"Password\\": \\"$API_PASS\\"}" | jq -r ".jwt" | tr -d "\n"`"'
|
|
# Update chaosbot:latest image
|
|
- 'curl -H "Content-Type: application/json" -H "Authorization: Bearer $AUTH_TOKEN" "$API_URI/api/endpoints/$ENDPOINT_URI/docker/images/create?fromImage=registry.chaoticlogic.us%2Fchaosbot:latest" -H "X-Registry-Auth: eyJzZXJ2ZXJhZGRyZXNzIjoicmVnaXN0cnkuY2hhb3RpY2xvZ2ljLnVzIn0=" --data-raw "{\\"fromImage\\":\\"registry.chaoticlogic.us/chaosbot:latest\\"}"'
|
|
# Stop old container
|
|
- 'curl -H "Content-Type: application/json" -H "Authorization: Bearer $AUTH_TOKEN" "$API_URI/api/endpoints/$ENDPOINT_URI/docker/containers/$CONTAINER_ID/stop" --data-raw "{}"'
|
|
# Rename old container
|
|
- 'curl -H "Content-Type: application/json" -H "Authorization: Bearer $AUTH_TOKEN" "$API_URI/api/endpoints/$ENDPOINT_URI/docker/containers/$CONTAINER_ID/rename?name=%2F$CONTAINER_ID-old" --data-raw "{}"'
|
|
# Create new container
|
|
- 'CONTAINER_CREATION_RESPONSE=`curl -H "Content-Type: application/json" -H "Authorization: Bearer $AUTH_TOKEN" "$API_URI/api/endpoints/$ENDPOINT_URI/docker/containers/create?name=$CONTAINER_ID" --data-raw "{\\"Cmd\\":[],\\"Entrypoint\\":[\\"./ChaosBot\\"],\\"Hostname\\":\\"b47984029a4a\\",\\"Image\\":\\"registry.chaoticlogic.us/chaosbot:latest\\",\\"Labels\\":{},\\"OnBuild\\":null,\\"OpenStdin\\":false,\\"StdinOnce\\":false,\\"Tty\\":false,\\"User\\":\\"\\",\\"Volumes\\":{\\"/App/appsettings.json\\":{}},\\"WorkingDir\\":\\"/App\\",\\"HostConfig\\":{\\"AutoRemove\\":false,\\"Binds\\":[\\"/etc/ChaosBot/appsettings.json:/App/appsettings.json:ro\\"],\\"RestartPolicy\\":{\\"MaximumRetryCount\\":0,\\"Name\\":\\"unless-stopped\\"}},\\"name\\":\\"ChaoticLogicBot\\",\\"ExposedPorts\\":{\\"8080/tcp\\":{}},\\"HostConfig\\":{\\"PortBindings\\":{\\"8080/tcp\\":[{\\"HostIp\\":\\"\\",\\"HostPort\\":\\"8001\\"}]}}}"`'
|
|
- 'NEW_CONTAINER_ID=`echo $CONTAINER_CREATION_RESPONSE | jq -r ".Id"`'
|
|
- 'NEW_RESOURCE_CONTROL_ID=`echo $CONTAINER_CREATION_RESPONSE | jq -r ".Portainer.ResourceControl.Id"`'
|
|
# Connect new container to docker bridge
|
|
- 'curl -H "Content-Type: application/json" -H "Authorization: Bearer $AUTH_TOKEN" "$API_URI/api/endpoints/$ENDPOINT_URI/docker/networks/bridge/connect" --data-raw "{\"Container\":\"$NEW_CONTAINER_ID\"}"'
|
|
# Start new container
|
|
- 'curl -H "Content-Type: application/json" -H "Authorization: Bearer $AUTH_TOKEN" "$API_URI/api/endpoints/$ENDPOINT_URI/docker/containers/$NEW_CONTAINER_ID/start" --data-raw "{}"'
|
|
# Lock down new container
|
|
- 'curl -X PUT -H "Content-Type: application/json" -H "Authorization: Bearer $AUTH_TOKEN" "$API_URI/api/resource_controls/$NEW_RESOURCE_CONTROL_ID" --data-raw "{\"AdministratorsOnly\":true,\"Public\":false,\"Users\":[],\"Teams\":[]}"'
|
|
# Delete old container
|
|
- 'curl -X DELETE "$API_URI/api/endpoints/$ENDPOINT_URI/docker/containers/$CONTAINER_ID-old?force=true&v=1" -H "Authorization: Bearer $AUTH_TOKEN"'
|