ci(portal): retarget image build to registry.meghsakha.com + orca webhook
ci / shared (pull_request) Successful in 14s
ci / test (pull_request) Successful in 10m17s
ci / e2e (pull_request) Has been skipped
ci / image (pull_request) Has been skipped

The previous CI pushed to registry.breakpilot.com (the future prod
registry that doesn't exist yet) and tried to call `orca apply`, a
CLI shape this orca version doesn't ship. Repointing to the live
infrastructure:

- registry: registry.meghsakha.com
- image path: breakpilot/portal (sibling of breakpilot/compliance-*)
- tags: :latest (for the webhook-driven deploy) + :sha-<sha> (traceability)
- redeploy: POST github-style payload to the orca webhook on the master,
  matching the pattern documented in orca-infra/WEBHOOKS.md

The webhook must be registered once on the master:
  orca webhooks add --repo platform/portal \
                    --service breakpilot-portal --branch main

CI also needs REGISTRY_USER + REGISTRY_PASS set on this Gitea repo's
Actions secrets — same htpasswd-backed creds the master uses today.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
Sharang Parnerkar
2026-06-10 12:12:44 +02:00
parent 00b968953e
commit 8fc4dc09c9
+19 -9
View File
@@ -108,6 +108,15 @@ jobs:
PLAYWRIGHT_TEST_PASS: ${{ secrets.STAGE_TEST_PASS }} PLAYWRIGHT_TEST_PASS: ${{ secrets.STAGE_TEST_PASS }}
image: image:
# Builds the portal image and ships it through the same path every
# other service in orca-infra uses: push :latest + :sha-<sha> to
# registry.meghsakha.com, then POST a github-style payload to the
# orca webhook so the master pulls and redeploys breakpilot-portal.
#
# Webhook target (registered once on the master via
# orca webhooks add --repo platform/portal \
# --service breakpilot-portal --branch main
# ) accepts unsigned payloads — orca matches on repo + branch.
needs: [shared, test] needs: [shared, test]
if: github.event_name == 'push' && github.ref == 'refs/heads/main' && hashFiles('Dockerfile') != '' if: github.event_name == 'push' && github.ref == 'refs/heads/main' && hashFiles('Dockerfile') != ''
runs-on: docker runs-on: docker
@@ -115,18 +124,19 @@ jobs:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- uses: docker/login-action@v3 - uses: docker/login-action@v3
with: with:
registry: registry.breakpilot.com registry: registry.meghsakha.com
username: ${{ secrets.REGISTRY_USER }} username: ${{ secrets.REGISTRY_USER }}
password: ${{ secrets.REGISTRY_PASS }} password: ${{ secrets.REGISTRY_PASS }}
- uses: docker/build-push-action@v6 - uses: docker/build-push-action@v6
with: with:
push: true push: true
tags: | tags: |
registry.breakpilot.com/${{ github.event.repository.name }}:sha-${{ github.sha }} registry.meghsakha.com/breakpilot/portal:latest
registry.breakpilot.com/${{ github.event.repository.name }}:env-stage registry.meghsakha.com/breakpilot/portal:sha-${{ github.sha }}
- uses: anchore/sbom-action@v0 - name: trigger orca redeploy
with: run: |
image: registry.breakpilot.com/${{ github.event.repository.name }}:sha-${{ github.sha }} curl -ksSf -X POST \
- run: orca apply --env=stage --image-tag=sha-${{ github.sha }} -H "Content-Type: application/json" \
env: -H "X-GitHub-Event: push" \
ORCA_TOKEN: ${{ secrets.ORCA_STAGE_TOKEN }} -d '{"repository":{"full_name":"platform/portal"},"ref":"refs/heads/main"}' \
https://46.225.100.82:6880/api/v1/webhooks/github