Skip to content

Commit

Permalink
Merge pull request #2 from dappforce/staging
Browse files Browse the repository at this point in the history
Init prod deployment
  • Loading branch information
mckrava authored Dec 5, 2023
2 parents 678d645 + bc31c32 commit 8f9cafd
Show file tree
Hide file tree
Showing 106 changed files with 16,139 additions and 0 deletions.
18 changes: 18 additions & 0 deletions .env.example
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
AGGREGATOR_DB_HOST=localhost
AGGREGATOR_DB_PORT=5434
AGGREGATOR_DB_USERNAME=postgres
AGGREGATOR_DB_PASSWORD=SuperSecret!23
AGGREGATOR_DB_DATABASE=postgres_opt_cold

REDIS_QUEUE_HOST=localhost
AGGREGATOR_REDIS_PASSWORD=qwerty
REDIS_QUEUE_PREFIX=dh_queue
REDIS_QUEUE_PORT=6379

DATA_SOURCE_GSQUID_MAIN_POLKADOT=https://squid.subsquid.io/gs-main-polkadot/graphql
DATA_SOURCE_GSQUID_MAIN_KUSAMA=https://squid.subsquid.io/gs-main-kusama/graphql
DATA_SOURCE_GSQUID_MAIN_MOONBEAM=https://squid.subsquid.io/gs-main-moonbeam/graphql
DATA_SOURCE_GSQUID_MAIN_MOONRIVER=https://squid.subsquid.io/gs-main-moonriver/graphql
DATA_SOURCE_GSQUID_MAIN_ASTAR=https://squid.subsquid.io/gs-main-astar/graphql

APP_PORT=8080
24 changes: 24 additions & 0 deletions .eslintrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
module.exports = {
parser: '@typescript-eslint/parser',
parserOptions: {
project: 'tsconfig.json',
sourceType: 'module',
},
plugins: ['@typescript-eslint/eslint-plugin'],
extends: [
'plugin:@typescript-eslint/recommended',
'plugin:prettier/recommended',
],
root: true,
env: {
node: true,
jest: true,
},
ignorePatterns: ['.eslintrc.js'],
rules: {
'@typescript-eslint/interface-name-prefix': 'off',
'@typescript-eslint/explicit-function-return-type': 'off',
'@typescript-eslint/explicit-module-boundary-types': 'off',
'@typescript-eslint/no-explicit-any': 'off',
},
};
81 changes: 81 additions & 0 deletions .github/workflows/feature-based-delete.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
name: Delete feature
on:
pull_request:
types: [closed]
branches:
- deploy/**

jobs:
delete:
if: github.event.pull_request.merged == true
name: deploy
runs-on: ubuntu-latest
steps:
- name: Checkout main
uses: actions/checkout@v3

- uses: mdecoleman/[email protected]
id: vars
with:
repo-token: ${{ secrets.GITHUB_TOKEN }}

- name: Extract branch name
shell: bash
run: echo "name=$(echo ${{ steps.vars.outputs.branch }} | sed 's/^deploy\///')" >> $GITHUB_ENV
id: extract_branch

- name: Install doctl
uses: digitalocean/action-doctl@v2
with:
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN_STAGING }}

- name: install helm
env:
HELM_VERSION: "3.9.2"
run: |
wget -q https://get.helm.sh/helm-v${HELM_VERSION}-linux-amd64.tar.gz
tar -xzf helm-v${HELM_VERSION}-linux-amd64.tar.gz
install linux-amd64/helm /usr/local/bin
helm version
- name: install kustomize
env:
KUSTOMIZE_VERSION: "4.5.6"
run: |
wget -q https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize%2Fv${KUSTOMIZE_VERSION}/kustomize_v${KUSTOMIZE_VERSION}_linux_amd64.tar.gz
tar -xzf kustomize_v${KUSTOMIZE_VERSION}_linux_amd64.tar.gz
install kustomize /usr/local/bin
kustomize version
- name: Save DigitalOcean kubeconfig with short-lived credentials
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 ${{ secrets.K8S_STAGING }}

- name: remove previous redis feature
continue-on-error: true
run: |
NAME=${{ env.name }} && sed -i 's|<BRANCH>|'${NAME}'|' $GITHUB_WORKSPACE/redis-k8s/base/kustomization.yaml
kustomize build $GITHUB_WORKSPACE/redis-k8s/overlays/staging/ --enable-helm | kubectl delete -f -
- name: remove previous aggregation feature
continue-on-error: true
run: |
NAME=${{ env.name }} && sed -i 's|<BRANCH>|'${NAME}'|' $GITHUB_WORKSPACE/deployment/feature-based/all.yaml
NAME=${{ env.name }} && sed -i 's|<BRANCH>|'${NAME}'|' $GITHUB_WORKSPACE/deployment/feature-based/deploy.yaml
NAME=${{ env.name }} && sed -i 's|<BRANCH>|'${NAME}'|' $GITHUB_WORKSPACE/deployment/feature-based/remove-job.yaml
kubectl delete -f $GITHUB_WORKSPACE/deployment/feature-based/all.yaml
kubectl delete -f $GITHUB_WORKSPACE/deployment/feature-based/deploy.yaml
kubectl create -f $GITHUB_WORKSPACE/deployment/feature-based/remove-job.yaml
- name: Get CF A record ID
continue-on-error: true
shell: bash
run: echo "record=$(echo $(curl -X GET "https://api.cloudflare.com/client/v4/zones/${{ secrets.CF_ZONE }}/dns_records?type=A&name=${{ env.name }}-aggregation.subsocial.network&content=174.138.105.155&proxied=true&page=1&per_page=100&order=type&direction=desc&match=all" -H "X-Auth-Email:${{ secrets.CF_MAIL }}" -H "Authorization:Bearer ${{ secrets.CF_TOKEN }}" -H "Content-Type:application/json" | jq . | jq -c '.result[]' | jq -r .id) )" >> $GITHUB_ENV
id: cf

- name: delete CF A record
continue-on-error: true
run: curl -X DELETE "https://api.cloudflare.com/client/v4/zones/${{ secrets.CF_ZONE }}/dns_records/${{ env.record }}" -H "X-Auth-Email:${{ secrets.CF_MAIL }}" -H "Authorization:Bearer ${{ secrets.CF_TOKEN }}" -H "Content-Type:application/json"

- name: final task
if: always()
run: echo "finished successfully"
149 changes: 149 additions & 0 deletions .github/workflows/feature-based.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,149 @@
name: Feature based build and deploy aggregation service
on:
push:
branches:
- deploy/**
jobs:
redis_deploy:
name: redis_deploy
runs-on: ubuntu-latest
steps:
- name: Checkout main
uses: actions/checkout@v3

- name: Extract branch name
shell: bash
run: echo "name=$(echo ${GITHUB_REF#refs/heads/} | sed 's/^deploy\///')" >> $GITHUB_ENV
id: extract_branch

- name: Install doctl
uses: digitalocean/action-doctl@v2
with:
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN_STAGING }}

- name: Save DigitalOcean kubeconfig with short-lived credentials
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 ${{ secrets.K8S_STAGING }}

- name: install helm
env:
HELM_VERSION: "3.9.2"
run: |
wget -q https://get.helm.sh/helm-v${HELM_VERSION}-linux-amd64.tar.gz
tar -xzf helm-v${HELM_VERSION}-linux-amd64.tar.gz
install linux-amd64/helm /usr/local/bin
helm version
- name: install kustomize
env:
KUSTOMIZE_VERSION: "4.5.6"
run: |
wget -q https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize%2Fv${KUSTOMIZE_VERSION}/kustomize_v${KUSTOMIZE_VERSION}_linux_amd64.tar.gz
tar -xzf kustomize_v${KUSTOMIZE_VERSION}_linux_amd64.tar.gz
install kustomize /usr/local/bin
kustomize version
- name: Update redis config files
run: NAME=${{ env.name }} && sed -i 's|<BRANCH>|'${NAME}'|' $GITHUB_WORKSPACE/redis-k8s/base/kustomization.yaml

- name: Deploy to DigitalOcean Kubernetes
run: |
kustomize build $GITHUB_WORKSPACE/redis-k8s/overlays/staging/ --enable-helm | kubectl apply -f -
aggregation_build:
name: build & Push aggregation Docker image to Docker Hub
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Extract branch name
shell: bash
run: echo "name=$(echo ${GITHUB_REF#refs/heads/} | sed 's/^deploy\///')" >> $GITHUB_ENV
id: extract_branch

- name: Prepare
id: prep
run: |
echo "image=dappforce/subsocial-aggregation:${{ env.name }}-$(echo $GITHUB_SHA | head -c7)" >> $GITHUB_ENV
- name: Set up Docker context for buildx
id: buildx-context
run: |
docker context create builders
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@master
with:
endpoint: builders
version: latest

- name: Login to DockerHub
uses: docker/login-action@master
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Cache Docker layers
uses: actions/cache@v3
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-single-buildx-${{ github.sha }}
restore-keys: |
${{ runner.os }}-single-buildx
- name: Build docker image
uses: docker/build-push-action@v4
with:
context: .
builder: ${{ steps.buildx.outputs.name }}
file: ./docker/Dockerfile
push: true
tags: |
${{ env.image }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new

- name: Move cache
run: |
rm -rf /tmp/.buildx-cache
mv /tmp/.buildx-cache-new /tmp/.buildx-cache
aggregation_deploy:
name: aggregation_deploy
needs: aggregation_build
runs-on: ubuntu-latest
steps:
- name: Checkout main
uses: actions/checkout@v3

- name: Extract branch name
shell: bash
run: echo "name=$(echo ${GITHUB_REF#refs/heads/} | sed 's/^deploy\///')" >> $GITHUB_ENV
id: extract_branch

- name: Install doctl
uses: digitalocean/action-doctl@v2
with:
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN_STAGING }}

- name: Save DigitalOcean kubeconfig with short-lived credentials
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 ${{ secrets.K8S_STAGING }}

- name: Update docker image name
run: TAG=${{ env.name }}-$(echo $GITHUB_SHA | head -c7) && sed -i 's|<IMAGE>|dappforce/subsocial-aggregation:'${TAG}'|' $GITHUB_WORKSPACE/deployment/feature-based/deploy.yaml

- name: Update config files
run: NAME=${{ env.name }} && sed -i 's|<BRANCH>|'${NAME}'|' $GITHUB_WORKSPACE/deployment/feature-based/all.yaml

- name: Update deploy file
run: NAME=${{ env.name }} && sed -i 's|<BRANCH>|'${NAME}'|' $GITHUB_WORKSPACE/deployment/feature-based/deploy.yaml

- name: Deploy to DigitalOcean Kubernetes
run: |
kubectl apply -f $GITHUB_WORKSPACE/deployment/feature-based/all.yaml
kubectl apply -f $GITHUB_WORKSPACE/deployment/feature-based/deploy.yaml
- name: Verify deployment
run: NAME=${{ env.name }} && kubectl -n sub-id rollout status deployment/aggregation-${NAME}

- name: CF deploy
run: curl -X POST "https://api.cloudflare.com/client/v4/zones/${{ secrets.CF_ZONE }}/dns_records" -H "X-Auth-Email:${{ secrets.CF_MAIL }}" -H "Authorization:Bearer ${{ secrets.CF_TOKEN }}" -H "Content-Type:application/json" --data '{"type":"A","name":"${{ env.name }}-aggregation.subsocial.network","content":"174.138.105.155","ttl":3600,"priority":10,"proxied":true}'
97 changes: 97 additions & 0 deletions .github/workflows/prod.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,97 @@
name: Build and deploy aggregation service to prod
on:
push:
branches:
- main
workflow_dispatch:

jobs:
aggregation_build:
name: build & Push aggregation Docker image to Docker Hub
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Extract branch name
shell: bash
run: echo "name=${GITHUB_REF#refs/heads/}" >> $GITHUB_ENV
id: extract_branch

- name: Prepare
id: prep
run: |
echo "image=dappforce/subsocial-aggregation:${{ env.name }}-$(echo $GITHUB_SHA | head -c7)" >> $GITHUB_ENV
- name: Set up Docker context for buildx
id: buildx-context
run: |
docker context create builders
- name: Set up Docker Buildx
id: buildx
uses: docker/setup-buildx-action@master
with:
endpoint: builders
version: latest

- name: Login to DockerHub
uses: docker/login-action@master
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Cache Docker layers
uses: actions/cache@v3
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-single-buildx-${{ github.sha }}
restore-keys: |
${{ runner.os }}-single-buildx
- name: Build docker image
uses: docker/build-push-action@v4
with:
context: .
builder: ${{ steps.buildx.outputs.name }}
file: ./docker/Dockerfile
push: true
tags: |
${{ env.image }}
cache-from: type=local,src=/tmp/.buildx-cache
cache-to: type=local,dest=/tmp/.buildx-cache-new

- name: Move cache
run: |
rm -rf /tmp/.buildx-cache
mv /tmp/.buildx-cache-new /tmp/.buildx-cache
aggregation_deploy:
name: aggregation_deploy
needs: aggregation_build
runs-on: ubuntu-latest
steps:
- name: Checkout main
uses: actions/checkout@v3

- name: Extract branch name
shell: bash
run: echo "name=${GITHUB_REF#refs/heads/}" >> $GITHUB_ENV
id: extract_branch

- name: Install doctl
uses: digitalocean/action-doctl@v2
with:
token: ${{ secrets.DIGITALOCEAN_ACCESS_TOKEN_PROD }}

- name: Save DigitalOcean kubeconfig with short-lived credentials
run: doctl kubernetes cluster kubeconfig save --expiry-seconds 600 ${{ secrets.K8S_PROD }}

- name: Update docker image name
run: TAG=${{ env.name }}-$(echo $GITHUB_SHA | head -c7) && sed -i 's|<IMAGE>|dappforce/subsocial-aggregation:'${TAG}'|' $GITHUB_WORKSPACE/deployment/prod/core/deploy.yaml

- name: Deploy to DigitalOcean Kubernetes
run: |
kubectl apply -f $GITHUB_WORKSPACE/deployment/prod/core/all.yaml
kubectl apply -f $GITHUB_WORKSPACE/deployment/prod/core/deploy.yaml
- name: Verify deployment
run: kubectl -n sub-id rollout status deployment/aggregation
Loading

0 comments on commit 8f9cafd

Please sign in to comment.