Skip to content

fix: hide obsolete services #323

fix: hide obsolete services

fix: hide obsolete services #323

Workflow file for this run

name: CI
on:
push:
branches: [ master, dev ]
env:
PRODUCTION_BRANCH: "master"
INGRESS_DOMAIN_master: "minter.network"
KUBE_NAMESPACE_master: "minter-network"
INGRESS_DOMAIN_dev: "minter-network.kubernetes.icu"
KUBE_NAMESPACE_dev: "default"
jobs:
ci:
runs-on: ubuntu-latest
steps:
- name: set env BUILD_BRANCH
run: echo "BUILD_BRANCH=$(echo $GITHUB_REF | sed 's:refs/heads/::')" >> $GITHUB_ENV
- name: set branch prefix env to be used during docker build, .e.g. "refs/heads/testnet" => ".testnet"
run: echo "BUILD_BRANCH_ENV_PREFIX=$(echo .$BUILD_BRANCH)" >> $GITHUB_ENV
- name: set env PROJECT_NAME
run: echo "PROJECT_NAME=$(echo $GITHUB_REPOSITORY | sed "s:MinterTeam/::")" >> $GITHUB_ENV
- name: set env INGRESS_DOMAIN
env:
INGRESS_DOMAIN_KEY: INGRESS_DOMAIN_${{ env.BUILD_BRANCH }}
run: echo "INGRESS_DOMAIN=$(echo ${!INGRESS_DOMAIN_KEY})" >> $GITHUB_ENV
- name: set env KUBE_NAMESPACE
env:
KUBE_NAMESPACE_KEY: KUBE_NAMESPACE_${{ env.BUILD_BRANCH }}
run: echo "KUBE_NAMESPACE=$(echo ${!KUBE_NAMESPACE_KEY})" >> $GITHUB_ENV
- uses: actions/checkout@v2
- name: build and push docker image
uses: opspresso/[email protected]
env:
USERNAME: ${{ secrets.MINTER_REGISTRY_USERNAME }}
PASSWORD: ${{ secrets.MINTER_REGISTRY_PASSWORD }}
REGISTRY: "registry.minter.network"
IMAGE_NAME: ${{ env.PROJECT_NAME }}
LATEST: "true"
TAG_NAME: ${{ github.sha }}
DOCKERFILE: ".docker/Dockerfile"
DOCKER_BUILD_ARGS: --build-arg BUILD_BRANCH_ENV_PREFIX
- name: DigitalOcean Kubernetes
if: env.BUILD_BRANCH == env.PRODUCTION_BRANCH
uses: matootie/[email protected]
with:
personalAccessToken: ${{ secrets.DIGITALOCEAN_TOKEN }}
clusterName: k8s-prod-do
- name: Install helm to DO
if: env.BUILD_BRANCH == env.PRODUCTION_BRANCH
run: wget https://get.helm.sh/helm-v3.3.4-linux-amd64.tar.gz &> /dev/null && tar xvzf helm-v3.3.4-linux-amd64.tar.gz && chmod 777 linux-amd64/helm && ./linux-amd64/helm ls -n ${{ env.KUBE_NAMESPACE }}
- name: Deploy to DO
if: env.BUILD_BRANCH == env.PRODUCTION_BRANCH
env:
TAG_NAME: ${{ github.sha }}
run: ./linux-amd64/helm upgrade -n ${{ env.KUBE_NAMESPACE }} -i $PROJECT_NAME chart/ --atomic --timeout 100s --set image.tag=$TAG_NAME --set ingress.domain=$INGRESS_DOMAIN --set ingress.tlsname=$INGRESS_DOMAIN
- name: deploy to production cluster
if: env.BUILD_BRANCH == env.PRODUCTION_BRANCH
uses: wahyd4/[email protected]
env:
KUBE_CONFIG_DATA: ${{ secrets.KUBE_PROD_CONFIG_DATA }}
TAG_NAME: ${{ github.sha }}
with:
args: helm upgrade -n $KUBE_NAMESPACE -i $PROJECT_NAME chart/ --atomic --timeout 100s --set image.tag=$TAG_NAME --set ingress.domain=$INGRESS_DOMAIN --set ingress.tlsname=$INGRESS_DOMAIN
- name: deploy to staging cluster
if: env.BUILD_BRANCH != env.PRODUCTION_BRANCH
uses: wahyd4/kubectl-helm-action@master
env:
KUBE_CONFIG_DATA: ${{ secrets.KUBE_STAGE_CONFIG_DATA }}
TAG_NAME: ${{ github.sha }}
with:
args: helm upgrade -n $KUBE_NAMESPACE -i ${{ env.PROJECT_NAME }} chart/ --atomic --timeout 100s --set image.tag=$TAG_NAME --set ingress.domain=$INGRESS_DOMAIN --set ingress.tlsname=$INGRESS_DOMAIN --set ingress.issuer=letsencrypt-http --set ingress.clusterissuer=""
- name: notification
if: cancelled() == false
uses: xinthink/[email protected]
with:
botToken: ${{ secrets.TELEGRAM_CI_TOKEN }}
chatId: ${{ secrets.TELEGRAM_CI_TO }}
jobStatus: ${{ job.status }}
skipSuccess: false