|
| 1 | +name: Build and Deploy digit-recognition/frontend |
| 2 | + |
| 3 | +on: |
| 4 | + workflow_dispatch: |
| 5 | + push: |
| 6 | + branches: ["*"] |
| 7 | + paths: |
| 8 | + - "digit-recognition/frontend/**" |
| 9 | + |
| 10 | +concurrency: |
| 11 | + group: ${{ github.workflow }}-${{ github.ref }} |
| 12 | + cancel-in-progress: true |
| 13 | + |
| 14 | +env: |
| 15 | + ENVIRONMENT: ${{ (github.ref == 'refs/heads/master' || github.ref == 'refs/heads/main') && 'prod' || 'stg' }} |
| 16 | + REGISTRY: ghcr.io/$(echo ${{ github.repository }} | tr '[:upper:]' '[:lower:]') |
| 17 | + AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} |
| 18 | + AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} |
| 19 | + AWS_REGION: ${{ secrets.AWS_REGION }} |
| 20 | + KUBECTL_VERSION: ${{ secrets.KUBECTL_VERSION }} |
| 21 | + KUBE_CONFIG_DATA: ${{ secrets.KUBE_CONFIG_DATA }} |
| 22 | + KUBE_NAMESPACE: gear-exe-dapps |
| 23 | + KUBE_DEPLOY_PREFIX: digit-recognition-frontend |
| 24 | + KUBE_DEPLOY_TYPE: deployment # (statefulset or deployment) |
| 25 | + |
| 26 | +jobs: |
| 27 | + prepair: |
| 28 | + runs-on: ubuntu-latest |
| 29 | + outputs: |
| 30 | + image_name: ${{ steps.image.outputs.image_name }} |
| 31 | + steps: |
| 32 | + - name: Checkout repository |
| 33 | + uses: actions/checkout@v4 |
| 34 | + |
| 35 | + - name: Get branch |
| 36 | + id: branch |
| 37 | + run: | |
| 38 | + branch_name=${GITHUB_REF#refs/heads/} |
| 39 | + echo "branch_name=$branch_name" >> $GITHUB_ENV |
| 40 | +
|
| 41 | + - name: Get short SHA |
| 42 | + id: sha |
| 43 | + run: | |
| 44 | + sha_short=$(git rev-parse --short HEAD) |
| 45 | + echo "sha_short=$sha_short" >> $GITHUB_ENV |
| 46 | +
|
| 47 | + - name: Set IMAGE_NAME |
| 48 | + id: image |
| 49 | + run: | |
| 50 | + image_name=${{ env.REGISTRY }}-${{ env.KUBE_DEPLOY_PREFIX }}:${{ env.branch_name }}-${{ env.sha_short }} |
| 51 | + echo "image_name=$image_name" >> $GITHUB_OUTPUT |
| 52 | +
|
| 53 | + build-and-push-image: |
| 54 | + needs: [prepair] |
| 55 | + runs-on: ubuntu-latest |
| 56 | + environment: ${{ (github.ref == 'refs/heads/master' || github.ref == 'refs/heads/main') && 'prod' || 'stg' }} |
| 57 | + permissions: |
| 58 | + contents: read |
| 59 | + packages: write |
| 60 | + steps: |
| 61 | + - name: Checkout repository |
| 62 | + uses: actions/checkout@v4 |
| 63 | + |
| 64 | + - name: Log in to the github container registry |
| 65 | + uses: docker/login-action@v3 |
| 66 | + with: |
| 67 | + registry: ${{ env.REGISTRY }} |
| 68 | + username: ${{ github.actor }} |
| 69 | + password: ${{ secrets.GITHUB_TOKEN }} |
| 70 | + |
| 71 | + - name: Build and push image |
| 72 | + uses: docker/build-push-action@v6 |
| 73 | + with: |
| 74 | + context: digit-recognition/frontend/ |
| 75 | + push: true |
| 76 | + build-args: | |
| 77 | + NODE_ENV=${{ env.NODE_ENV }} |
| 78 | + VITE_WALLET_CONNECT_PROJECT_ID=${{ env.VITE_WALLET_CONNECT_PROJECT_ID }} |
| 79 | + VITE_GEAR_API_NODE=${{ env.VITE_GEAR_API_NODE }} |
| 80 | + VITE_ETH_NODE_ADDRESS=${{ env.VITE_ETH_NODE_ADDRESS }} |
| 81 | + VITE_CONTRACT_ADDRESS=${{ env.VITE_CONTRACT_ADDRESS }} |
| 82 | + tags: ${{ needs.prepair.outputs.image_name }} |
| 83 | + |
| 84 | + deploy-to-k8s: |
| 85 | + needs: [prepair, build-and-push-image] |
| 86 | + runs-on: ubuntu-latest |
| 87 | + environment: ${{ (github.ref == 'refs/heads/master' || github.ref == 'refs/heads/main') && 'prod' || 'stg' }} |
| 88 | + steps: |
| 89 | + - name: Setup kubectl |
| 90 | + run: | |
| 91 | + curl -LO "https://dl.k8s.io/release/${{ env.KUBECTL_VERSION }}/bin/linux/amd64/kubectl" |
| 92 | + chmod +x kubectl |
| 93 | + sudo mv kubectl /usr/local/bin/ |
| 94 | + mkdir -p $HOME/.kube/ |
| 95 | + echo "${{ env.KUBE_CONFIG_DATA }}" | base64 -d > $HOME/.kube/config |
| 96 | +
|
| 97 | + - name: Configure AWS credentials |
| 98 | + uses: aws-actions/configure-aws-credentials@v4 |
| 99 | + with: |
| 100 | + aws-access-key-id: ${{ env.AWS_ACCESS_KEY_ID }} |
| 101 | + aws-secret-access-key: ${{ env.AWS_SECRET_ACCESS_KEY }} |
| 102 | + aws-region: ${{ env.AWS_REGION }} |
| 103 | + |
| 104 | + - name: Get containes |
| 105 | + id: containers |
| 106 | + run: | |
| 107 | + containers=$(kubectl get ${{ env.KUBE_DEPLOY_TYPE }}/${{ env.KUBE_DEPLOY_PREFIX }}-${{ env.ENVIRONMENT }} -n ${{ env.KUBE_NAMESPACE }} -o jsonpath="{.spec.template.spec.containers[*].name}") |
| 108 | + echo "CONTAINERS=$containers" >> $GITHUB_ENV |
| 109 | +
|
| 110 | + - name: Update deployment image |
| 111 | + run: | |
| 112 | + for container in ${{ env.CONTAINERS }}; do |
| 113 | + kubectl set image ${{ env.KUBE_DEPLOY_TYPE }}/${{ env.KUBE_DEPLOY_PREFIX }}-${{ env.ENVIRONMENT }} $container=${{ needs.prepair.outputs.image_name }} -n ${{ env.KUBE_NAMESPACE }}; |
| 114 | + done |
| 115 | +
|
| 116 | + - name: Restart deployment |
| 117 | + run: | |
| 118 | + kubectl rollout restart ${{ env.KUBE_DEPLOY_TYPE }}/${{ env.KUBE_DEPLOY_PREFIX }}-${{ env.ENVIRONMENT }} -n ${{ env.KUBE_NAMESPACE }} |
| 119 | +
|
| 120 | + - name: Check deployment |
| 121 | + run: | |
| 122 | + kubectl rollout status ${{ env.KUBE_DEPLOY_TYPE }}/${{ env.KUBE_DEPLOY_PREFIX }}-${{ env.ENVIRONMENT }} --timeout=300s -n ${{ env.KUBE_NAMESPACE }} |
0 commit comments