Skip to content

Create and publish backend image #57

Create and publish backend image

Create and publish backend image #57

name: Create and publish backend image
on:
release:
types: [published]
workflow_dispatch:
inputs:
tags:
description: 'Docker image tag (e.g: v0.0.1)'
required: false
type: string
env:
IMAGE_NAME: cohere-toolkit-backend
jobs:
build-and-push-backend-image:
runs-on: ubuntu-latest
permissions:
contents: read
steps:
- name: Login
uses: google-github-actions/setup-gcloud@v0
with:
project_id: ${{ vars.GCP_PROJECT_ID }}
service_account_email: [email protected]
service_account_key: ${{ secrets.GCP_SA_KEY }}
- name: Configure Docker
run: gcloud auth configure-docker --quiet
- name: Checkout repository
uses: actions/checkout@v2
- run: 'echo "$KEY" > ./key.json'
shell: bash
env:
KEY: ${{ secrets.GCP_SA_KEY }}
# - name: Checkout code
# uses: actions/checkout@v2
# - name: Set up Docker Buildx
# uses: docker/setup-buildx-action@v1
# - name: Decode and write GCP key to file
# run: echo "${{ secrets.GCP_SA_KEY_B64 }}" | base64 --decode > /tmp/gcp_sa_key.json
# - name: Authenticate to Google Cloud
# run: |
# gcloud auth activate-service-account --key-file=/tmp/gcp_sa_key.json
# gcloud auth configure-docker us-docker.pkg.dev --quiet
# - name: Checkout repository
# uses: actions/checkout@v4
# - name: Set up Docker Buildx
# uses: docker/setup-buildx-action@v1
# - name: Authenticate with service account
# uses: google-github-actions/auth@v1
# with:
# credentials_json: ${{ secrets.GCP_SA_KEY }}
# # - name: Login
# # uses: google-github-actions/setup-gcloud@v1
# - name: Set up Cloud SDK
# uses: google-github-actions/setup-gcloud@v1
# with:
# project_id: ${{ vars.GCP_PROJECT_ID }}
# service_account_key: ${{ secrets.GCP_SA_KEY }}
# - name: Configure Docker to use Google Cloud credentials
# run: gcloud auth configure-docker us-docker.pkg.dev
# export_default_credentials: true
# - name: Configure Docker
# run: yes | gcloud auth configure-docker us-docker.pkg.dev
# - name: Checkout repository
# uses: actions/checkout@v2
# - name: Extract metadata (tags, labels) for Docker
# id: meta
# uses: docker/metadata-action@v3
# with:
# images: ${{ vars.REGISTRY }}/${{ env.IMAGE_NAME }}
# - name: Build Docker image
# run: |
# docker build -t ${{ env.IMAGE_NAME }} -f ./src/backend/Dockerfile .
# # - name: Pull docker hello-world image
# # run: docker pull hello-world
# # - name: Tag Docker image
# # run: |
# # docker tag hello-world ${{ vars.REGISTRY }}/hello-world
# # # Save the SA key to a file so that it can be used by the docker build
# # - name: Save SA key to file
# # run: echo "${{ secrets.GCP_SA_KEY }}" > /tmp/gcp_sa_key.json
# # - name: Try auth again!
# # run: |
# # gcloud auth activate-service-account --key-file /tmp/gcp_sa_key.json
# # gcloud auth configure-docker --quiet
# # docker login -u _json_key -p "$(cat /tmp/gcp_sa_key.json)" https://gcr.io
# # - name: Push Docker image
# # run: |
# # docker push ${{ vars.REGISTRY }}/hello-world
# - name: Tag Docker image
# run: |
# docker tag ${{ env.IMAGE_NAME }} ${{ steps.meta.outputs.tags }}
# - name: Push Docker image
# env:
# THE_TAGS: ${{ steps.meta.outputs.tags }}
# run: |
# docker push ${{ steps.meta.outputs.tags }}
# Deploy the image to Cloud Run
- name: Deploy to Cloud Run
run: |
gcloud run deploy ${{ env.IMAGE_NAME }} \
--image=${{ steps.meta.outputs.tags }} \
--platform=managed \
--region=us-central1 \
--allow-unauthenticated \
--update-env-vars=DATABASE_URL=${{ secrets.DATABASE_URL }},COHERE_API_KEY=${{ secrets.COHERE_API_KEY }} \
--memory=4Gi \
--cpu=4 \
--max-instances=1