Remove service account activation from CI/CD workflow to enhance secu… #12
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: CICD | |
| on: | |
| push: | |
| branches: [main] | |
| pull_request: | |
| branches: ['*'] | |
| jobs: | |
| build: | |
| name: CICD | |
| runs-on: ubuntu-latest | |
| steps: | |
| - name: Checkout code | |
| uses: actions/checkout@v3 | |
| - name: Setup Bun | |
| uses: oven-sh/setup-bun@v1 | |
| with: | |
| bun-version: latest | |
| - name: Install dependencies | |
| run: bun install | |
| - name: Check format and lint | |
| run: | | |
| bun run format | |
| bun run lint | |
| # TODO: tests | |
| - name: Build project | |
| run: bun run build | |
| - name: Set up Docker Buildx | |
| uses: docker/setup-buildx-action@v2 | |
| - name: Log in to Google Artifact Registry | |
| uses: docker/login-action@v2 | |
| with: | |
| registry: europe-west1-docker.pkg.dev | |
| username: _json_key | |
| password: ${{ secrets.GCP_SA_KEY }} | |
| id: login | |
| continue-on-error: false | |
| - name: Build and push Docker image | |
| run: | | |
| IMAGE_NAME=europe-west1-docker.pkg.dev/${{ secrets.GCP_PROJECT }}/bitte-ai-mcp/bitte-mcp-sse | |
| docker build -t $IMAGE_NAME:${GITHUB_SHA::6} -t $IMAGE_NAME:latest -f apps/bitte-ai/Dockerfile . | |
| docker push $IMAGE_NAME:${GITHUB_SHA::6} | |
| docker push $IMAGE_NAME:latest | |
| - name: Google Auth | |
| id: auth | |
| uses: google-github-actions/auth@v1 | |
| with: | |
| credentials_json: '${{ secrets.GCP_SA_KEY }}' | |
| - name: Set up Google Cloud SDK | |
| uses: google-github-actions/setup-gcloud@v1 | |
| with: | |
| project_id: ${{ secrets.GCP_PROJECT }} | |
| - name: Deploy to Cloud Run | |
| run: | | |
| IMAGE_NAME=europe-west1-docker.pkg.dev/${{ secrets.GCP_PROJECT }}/bitte-ai-mcp/bitte-mcp-sse:${GITHUB_SHA::6} | |
| if [ "${{ github.ref }}" == "refs/heads/main" ]; then | |
| SERVICE_NAME=bitte-mcp-sse | |
| else | |
| SERVICE_NAME=bitte-mcp-sse-debug | |
| fi | |
| SECRETS='OPENAI_API_KEY=OPENAI_API_KEY:latest' | |
| SECRETS+=',ANTHROPIC_API_KEY=ANTHROPIC_API_KEY:latest' | |
| SECRETS+=',XAI_API_KEY=XAI_API_KEY:latest' | |
| SECRETS+=',GCP_SERVICE_ACCOUNT_KEY=FIREBASE_SERVICE_ACCOUNT_KEY:latest' | |
| SECRETS+=',DISCOVERY_AGENT_ID=DISCOVERY_AGENT_ID:latest' | |
| SECRETS+=',DISCOVERY_VECTOR_STORE_ID=DISCOVERY_VECTOR_STORE_ID:latest' | |
| SECRETS+=',PIMLICO_KEY=PIMLICO_KEY:latest' | |
| SECRETS+=',KV_REST_API_URL=KV_REST_API_URL:latest' | |
| SECRETS+=',KV_REST_API_TOKEN=KV_REST_API_TOKEN:latest' | |
| SECRETS+=',UNKEY_API_ID=UNKEY_API_ID:latest' | |
| SECRETS+=',UNKEY_API_KEY=UNKEY_API_KEY:latest' | |
| SECRETS+=',BITTE_API_KEY=BITTE_API_KEY:latest' | |
| ENV='NEAR_RPC_URL=https://free.rpc.fastnear.com/' | |
| ENV+=',NEAR_NETWORK_ID=mainnet' | |
| ENV+=',GCP_PROJECT_ID=${{ secrets.GCP_PROJECT }}' | |
| ENV+=',BITTE_REGISTRY_URL=https://registry.bitte.ai' | |
| ENV+=',BITTE_RUNTIME_URL=https://api.bitte.ai' | |
| gcloud run deploy $SERVICE_NAME \ | |
| --image $IMAGE_NAME \ | |
| --region europe-west1 \ | |
| --project ${{ secrets.GCP_PROJECT }} \ | |
| --update-env-vars "$ENV" \ | |
| --update-secrets "$SECRETS" \ | |
| --allow-unauthenticated |