Barcode Betty
8ed8226e20
ci: never hard-fail deploy-dev/deploy-uat on infra-PR merge outcome (CAR-1216)
...
CI / test (pull_request) Successful in 13s
CI / lint (pull_request) Successful in 14s
CI / audit (pull_request) Failing after 13s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 53s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m24s
The CI bot cannot self-approve cartsnitch/infra main's required human
review, so the in-job auto-merge attempt is structurally impossible
and would always fail with SOME message (checks-pending, then
approvals, then transient errors). Special-casing individual error
strings is fragile — CAR-1212's 'Does not have enough approvals' branch
proved it (deploy-dev run 4999 hit the final else-branch instead).
Make job success depend only on the infra PR being OPENED (and
cs_savannah review requested), NOT on the merge outcome. Replace both
the approvals-elif branch and the final else (exit 1) branch with a
single non-failing branch: emit a ::notice:: with the merge response
and exit 0. The ONLY remaining hard-fail is the empty PR_NUM check
(PR could not be created).
Same change applied symmetrically to deploy-uat.
Refs CAR-1195, CAR-1194, CAR-1212, CAR-1216.
2026-06-03 22:05:37 +00:00
Savannah Savings
284b361f9b
Merge pull request 'ci: deploy-dev/deploy-uat: report success on infra-main approval gate (CAR-1212)' ( #276 ) from betty/car-1212-approval-gate-exit0 into dev
CI / lint (push) Successful in 14s
CI / audit (push) Failing after 13s
CI / test (push) Successful in 14s
CI / lint (pull_request) Successful in 12s
CI / e2e (push) Successful in 42s
CI / build-and-push-api (push) Successful in 1m2s
CI / build-and-push-auth (push) Successful in 32s
CI / lighthouse (push) Failing after 1m21s
CI / audit (pull_request) Failing after 13s
CI / test (pull_request) Successful in 16s
CI / build-and-push-receiptwitness (push) Successful in 1m52s
CI / e2e (pull_request) Successful in 47s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / build-and-push (push) Successful in 50s
CI / lighthouse (pull_request) Failing after 1m16s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-uat (push) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / deploy-dev (push) Failing after 8s
2026-06-03 21:49:04 +00:00
Barcode Betty
3dcf0ce021
ci: treat infra PR approvals gate as success in deploy jobs (CAR-1212)
...
CI / lint (pull_request) Successful in 12s
CI / test (pull_request) Successful in 12s
CI / audit (pull_request) Failing after 12s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 43s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m17s
Per the spec for CAR-1212 (CAR-1195 follow-up):
- deploy-dev and deploy-uat now request cs_savannah as a reviewer on the
cartsnitch/infra PR (best-effort, log on non-2xx, never fail the job).
- After the merge attempt, classify the response:
* .merged == true -> success notice
* 'Does not have enough approvals' -> ::notice:: + exit 0
(GitOps approval gate, not a
failure; the PR is correctly
opened and surfaces in the CTO
queue)
* anything else -> keep the existing ::error::
and exit 1 (genuine unexpected
failure)
This unblocks the deploy jobs that were hard-failing on the branch-protection
approvals requirement, which a CI bot cannot self-satisfy. The CTO (cs_savannah)
already backstop-approves+merges these infra PRs by hand (e.g. #321 , #322 ).
- 'No image changes to deploy' early-exit preserved.
- Still uses secrets.CI_GITEA_TOKEN for the PR/reviewer/merge API calls.
- No git push origin main: only the API path is used.
Refs CAR-1195, CAR-1194.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-06-03 21:34:18 +00:00
Savannah Savings
440d7ac7e7
Merge pull request 'fix(ci): deploy jobs land image bump via PR (CAR-1195, CAR-1194)' ( #274 ) from betty/car-1195-pr-based-deploy into dev
CI / e2e (push) Successful in 43s
CI / audit (push) Successful in 10s
CI / lint (push) Successful in 12s
CI / test (push) Successful in 13s
CI / build-and-push-api (push) Successful in 1m6s
CI / build-and-push-receiptwitness (push) Successful in 2m6s
CI / build-and-push (push) Successful in 47s
CI / lighthouse (push) Failing after 1m52s
CI / deploy-uat (push) Has been skipped
CI / deploy-dev (push) Failing after 7s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / lint (pull_request) Successful in 13s
CI / test (pull_request) Successful in 13s
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / build-and-push (pull_request) Has been skipped
CI / audit (pull_request) Successful in 12s
CI / e2e (pull_request) Successful in 40s
CI / lighthouse (pull_request) Failing after 1m14s
CI / build-and-push-auth (push) Successful in 30s
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
2026-06-03 21:06:44 +00:00
Barcode Betty
83b553b58e
ci: delete overlay deploy branches after merge
...
CI / lint (pull_request) Successful in 13s
CI / test (pull_request) Successful in 12s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / audit (pull_request) Successful in 10s
CI / e2e (pull_request) Successful in 43s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m16s
Set delete_branch_after_merge:true on the auto-merge POST in both
deploy-dev and deploy-uat so the per-deploy branches in
cartsnitch/infra (ci/deploy-{dev,uat}-${GITHUB_SHA}) are removed
once their overlay image-tag bump lands on main. Without this flag
every successful deploy would leave a branch behind, accumulating
in cartsnitch/infra and making future re-runs of the same SHA
un-actionable from the existing branch name.
Refs CAR-1195 (CTO fix #2 ).
2026-06-03 20:53:54 +00:00
Barcode Betty
3a69ec29b5
fix(ci): bind deploy PR API to secrets.CI_GITEA_TOKEN (CAR-1195)
...
CI / test (pull_request) Successful in 12s
CI / audit (pull_request) Successful in 11s
CI / lint (pull_request) Successful in 13s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 43s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m16s
deploy-dev and deploy-uat had CI_GITEA_TOKEN: ${{ secrets.REGISTRY_TOKEN }}
which is the package-scoped container-registry token. PR creation and
auto-merge against cartsnitch/infra would 403 on the first real push.
Bind to secrets.CI_GITEA_TOKEN (the token the infra checkout already
uses for branch push) so the Gitea API calls have repo-write scope.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-06-03 20:39:21 +00:00
Barcode Betty
2573de86d5
Update .gitea/workflows/ci.yml
CI / lint (pull_request) Successful in 11s
CI / test (pull_request) Successful in 11s
CI / audit (pull_request) Successful in 12s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 45s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m12s
2026-06-03 20:09:56 +00:00
Barcode Betty
06162f9f15
fix(ci): unblock dev build/deploy (CAR-1195)
CI / audit (push) Failing after 3s
CI / lint (push) Successful in 13s
CI / test (push) Successful in 13s
CI / e2e (push) Successful in 41s
CI / build-and-push-auth (push) Successful in 41s
CI / lighthouse (push) Failing after 1m15s
CI / build-and-push (push) Successful in 58s
CI / build-and-push-api (push) Successful in 2m48s
CI / build-and-push-receiptwitness (push) Failing after 3m35s
CI / deploy-uat (push) Has been skipped
CI / deploy-dev (push) Failing after 5s
2026-06-03 19:43:54 +00:00
Savannah Savings
fb70b816f2
Merge pull request 'fix(receiptwitness): pool DB engine and Redis client to prevent connection exhaustion' ( #273 ) from barcode-betty/car-1078-email-worker-dragonfly-reset into dev
CI / e2e (push) Successful in 45s
CI / build-and-push (push) Failing after 2m14s
CI / build-and-push-receiptwitness (push) Failing after 3m45s
CI / deploy-uat (push) Has been skipped
CI / test (push) Successful in 11s
CI / lint (push) Successful in 14s
CI / lighthouse (push) Failing after 1m19s
CI / build-and-push-api (push) Failing after 3m12s
CI / build-and-push-auth (push) Failing after 2m44s
CI / deploy-dev (push) Failing after 34s
CI / audit (push) Successful in 11s
2026-06-03 19:20:31 +00:00
Coupon Carl
d92bcf433b
fix(ci): remove actions/setup-node from lint job to bypass corrupted runner cache
...
CI / test (pull_request) Successful in 12s
CI / lint (pull_request) Successful in 13s
CI / audit (pull_request) Successful in 12s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 45s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m16s
Runner pod gitea-act-runner-cartsnitch-85b5984bb-527xw has a corrupt
/root/.cache/act clone of actions/setup-node (missing dist/setup/index.js).
SHA-pinning changed the cache hash but the fresh clone on that pod still
ends up missing the dist directory.
catthehacker/ubuntu:act-latest ships Node pre-installed; the lint job only
needs ESLint + tsc, both of which are devDependencies installed by npm ci.
Removing actions/setup-node from lint bypasses the corrupt pod cache entirely
without affecting other jobs.
Refs CAR-1162
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-06-03 19:07:14 +00:00
Barcode Betty
01ed6dac00
fix(deps): pin safe versions of audit-flagged transitive deps (CAR-1162 audit)
...
CI / lint (pull_request) Failing after 6s
CI / test (pull_request) Successful in 12s
CI / audit (pull_request) Successful in 12s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 40s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m11s
The CI's npm audit (10.8.2) flagged three transitive vulnerabilities
that local newer-npm runs (11.x) miss due to advisory-DB divergence:
- @babel/plugin-transform-modules-systemjs: 7.29.0 -> ^7.29.4
(CVE-2026-44728: arbitrary code generation, fixed in 7.29.4)
- fast-uri: 3.1.0 -> ^3.1.2
(path traversal / host confusion via percent-encoded segments)
- brace-expansion: 5.0.5 -> >=5.0.6
(DoS via large numeric range defeating max protection)
These are non-breaking transitive updates within the same major
version. The previous override for brace-expansion (>=1.1.13) was
too loose to exclude 5.0.2-5.0.5; tightening it to >=5.0.6.
Ref CAR-1162, CAR-1122, CAR-1078
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-06-03 15:53:46 +00:00
Barcode Betty
a7a55bbf79
fix(ci): unblock dev PR #271 CI
...
CI / audit (pull_request) Failing after 14s
CI / lighthouse (pull_request) Has been skipped
CI / build-and-push (pull_request) Has been skipped
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / test (pull_request) Successful in 16s
CI / lint (pull_request) Successful in 18s
CI / e2e (pull_request) Successful in 52s
- Remove .mcp.json (scope creep, unrelated to CAR-1078)
- Bump vitest to ^4.1.8 (fixes GHSA-5xrq-8626-4rwp critical)
- Run npm audit fix for non-breaking vulns
- Pin actions/checkout and actions/setup-node to commit SHAs
in .gitea/workflows/ci.yml to force a clean cache fetch on
the act runner (workaround for corrupted /root/.cache/act cache)
Refs CAR-1162, CAR-1122, CAR-1078
2026-06-03 11:41:19 +00:00
Flea Flicker
fb0bb0102c
fix(receiptwitness): pool DB engine and Redis client to prevent connection exhaustion
...
CI / test (pull_request) Failing after 3s
CI / lighthouse (pull_request) Has been skipped
CI / e2e (pull_request) Failing after 4s
CI / audit (pull_request) Failing after 14s
CI / lint (pull_request) Successful in 16s
CI / build-and-push (pull_request) Has been skipped
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
email_worker calls get_async_session_factory() inside every resolve_user()
call, which creates a brand-new async engine (and thus a brand-new
connection pool) on every message. In a tight consumer loop processing
5 messages per batch, this rapidly exhausts DragonflyDB/Postgres
connection limits and manifests as ConnectionResetError.
Fix: cache the async engine in a module-level dict keyed by URL in
cartsnitch_common.database:get_async_engine(), matching the pattern
already used in receiptwitness:events.py for the Redis connection pool.
Also add pool_size=10, max_overflow=20, pool_pre_ping=True for
健壮连接管理.
Similarly, receiptwitness/queue/email.py:get_redis() was creating a new
Redis connection on every call with no pooling. Share a
ConnectionPool (max_connections=30) across all get_redis() callers.
Fixes CAR-1078
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-28 18:53:05 +00:00
Chris Farhood
d90b00d7ac
Add .mcp.json
CI / lint (push) Successful in 14s
CI / test (push) Successful in 11s
CI / audit (push) Failing after 10s
CI / e2e (push) Successful in 43s
CI / lighthouse (push) Failing after 44s
CI / build-and-push-receiptwitness (push) Failing after 11s
CI / build-and-push-api (push) Failing after 16s
CI / build-and-push-auth (push) Failing after 10s
CI / build-and-push (push) Failing after 12s
CI / deploy-uat (push) Failing after 27s
CI / deploy-dev (push) Failing after 31s
2026-05-25 21:47:10 +00:00
Savannah Savings
8983fe5d8f
Merge pull request 'Promote to Production: CAR-894 Gitea workflows migration' ( #270 ) from uat into main
CI / lint (push) Successful in 12s
CI / test (push) Successful in 12s
CI / audit (push) Failing after 21s
CI / e2e (push) Successful in 40s
CI / build-and-push-receiptwitness (push) Failing after 31s
CI / build-and-push-api (push) Failing after 15s
CI / lighthouse (push) Failing after 46s
CI / build-and-push-auth (push) Failing after 19s
CI / build-and-push (push) Failing after 12s
CI / deploy-dev (push) Failing after 33s
CI / deploy-uat (push) Failing after 32s
2026-05-24 18:51:41 +00:00
Savannah Savings
a26082d099
Merge pull request 'Promote dev → uat: Fix API crash (dispose_engine import)' ( #268 ) from dev into uat
...
CI / build-and-push-auth (push) Failing after 10s
CI / test (push) Successful in 14s
CI / build-and-push-receiptwitness (push) Failing after 12s
CI / build-and-push-api (push) Failing after 13s
CI / deploy-dev (push) Has been skipped
CI / audit (push) Failing after 10s
CI / lint (push) Successful in 15s
CI / e2e (push) Successful in 39s
CI / build-and-push (push) Failing after 10s
CI / lighthouse (push) Failing after 41s
CI / deploy-uat (push) Failing after 48s
CI / lint (pull_request) Successful in 40s
CI / e2e (pull_request) Successful in 40s
CI / audit (pull_request) Failing after 1m12s
CI / test (pull_request) Successful in 1m18s
CI / build-and-push (pull_request) Has been skipped
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 46s
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
Merge PR #268 : Promote dev → uat — Fix API crash (dispose_engine import)
Promotes fix for ImportError/CrashLoopBackOff to UAT environment.
Approved-by: Savannah Savings (CTO)
2026-05-23 15:52:56 +00:00
Savannah Savings
f8b8f4feef
Merge pull request 'Fix API crash: remove dead dispose_engine import' ( #266 ) from fix/dispose-engine-import into dev
...
CI / build-and-push (push) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push (pull_request) Has been skipped
CI / deploy-uat (push) Has been skipped
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / deploy-dev (push) Failing after 1m46s
CI / test (push) Failing after 1m38s
CI / test (pull_request) Failing after 1m27s
CI / lighthouse (pull_request) Has been skipped
CI / audit (pull_request) Failing after 1m31s
CI / e2e (pull_request) Failing after 1m34s
CI / build-and-push-api (push) Has been skipped
CI / lint (push) Failing after 1m29s
CI / audit (push) Failing after 1m31s
CI / lighthouse (push) Has been skipped
CI / e2e (push) Failing after 1m36s
CI / build-and-push-receiptwitness (push) Has been skipped
CI / build-and-push-auth (push) Has been skipped
CI / lint (pull_request) Failing after 1m30s
Merge PR #266 : Fix API crash — remove dead dispose_engine import
Removes non-existent dispose_engine import from main.py that caused ImportError and CrashLoopBackOff on API pods.
Reviewed-by: Checkout Charlie (QA PASS)
Approved-by: Savannah Savings (CTO)
2026-05-23 15:52:33 +00:00
Flea Flicker
5464e1a671
Fix API crash: remove dead dispose_engine import
...
CI / test (pull_request) Failing after 1m26s
CI / lighthouse (pull_request) Has been skipped
CI / lint (pull_request) Failing after 1m31s
CI / audit (pull_request) Failing after 1m33s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Failing after 1m38s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
ImportError: cannot import name 'dispose_engine' from 'cartsnitch_api.database'
The function does not exist and is unused - lifespan already calls close_db() directly.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-23 15:11:00 +00:00
Savannah Savings
c39b26050b
Merge pull request 'Promote dev → uat: CI registry migration [CAR-933]' ( #265 ) from dev into uat
...
CI / test (push) Failing after 1m28s
CI / lighthouse (push) Has been skipped
CI / build-and-push-api (push) Has been skipped
CI / build-and-push-auth (push) Has been skipped
CI / lint (push) Failing after 1m34s
CI / build-and-push-receiptwitness (push) Has been skipped
CI / build-and-push (push) Has been skipped
CI / audit (push) Failing after 1m32s
CI / e2e (push) Failing after 1m37s
CI / deploy-dev (push) Has been skipped
CI / deploy-uat (push) Failing after 1m30s
Promote dev → uat: CI registry migration [CAR-933] (#265 )
2026-05-23 14:39:41 +00:00
Savannah Savings
9cc1e49d86
Merge pull request 'ci(CAR-933): migrate image registry from ghcr.io to Gitea' ( #264 ) from carl/car-933-gitea-registry into dev
...
CI / test (push) Failing after 1m26s
CI / lighthouse (push) Has been skipped
CI / e2e (push) Failing after 1m31s
CI / lint (push) Failing after 1m41s
CI / audit (push) Failing after 1m39s
CI / build-and-push (push) Has been skipped
CI / build-and-push-receiptwitness (push) Has been skipped
CI / build-and-push-api (push) Has been skipped
CI / build-and-push-auth (push) Has been skipped
CI / deploy-uat (push) Has been skipped
CI / deploy-dev (push) Failing after 1m27s
CI / lint (pull_request) Failing after 1m28s
CI / test (pull_request) Failing after 1m33s
CI / lighthouse (pull_request) Has been skipped
CI / e2e (pull_request) Failing after 1m34s
CI / audit (pull_request) Failing after 1m39s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
Merge PR #264 : Migrate CI from ghcr.io to Gitea package registry (CAR-955)
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-23 14:35:15 +00:00
Coupon Carl
2c4e9985b1
ci: rename GITEA_TOKEN -> REGISTRY_TOKEN to match configured secret name
...
CI / test (pull_request) Failing after 1m24s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / lighthouse (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / build-and-push (pull_request) Has been skipped
CI / audit (pull_request) Failing after 1m33s
CI / lint (pull_request) Failing after 1m38s
CI / e2e (pull_request) Failing after 1m36s
CI / deploy-uat (pull_request) Has been skipped
cpfarhood confirmed the Gitea registry token is configured as REGISTRY_TOKEN
(not GITEA_TOKEN). This applies to both the registry docker login steps
and the infra repo checkout steps in deploy-dev/deploy-uat.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-23 14:29:45 +00:00
cartsnitch-ci[bot]
821f1d20b3
fix(ci): replace hardcoded cs_carl username and fix kustomize image rename syntax
...
CI / audit (pull_request) Failing after 1m26s
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Failing after 1m32s
CI / build-and-push (pull_request) Has been skipped
CI / lighthouse (pull_request) Has been skipped
CI / lint (pull_request) Failing after 1m29s
CI / test (pull_request) Failing after 1m34s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
- Replace hardcoded 'cs_carl' Gitea registry username with '${{ github.actor }}' in all 5 login steps
- Use kustomize 'OLD=NEW:TAG' rename syntax so existing ghcr.io image entries are updated instead of duplicated
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-23 14:27:24 +00:00
Coupon Carl
555ced4fdc
ci: migrate image registry from ghcr.io to git.farh.net
...
CI / lint (pull_request) Failing after 1m26s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / e2e (pull_request) Failing after 1m26s
CI / lighthouse (pull_request) Has been skipped
CI / audit (pull_request) Failing after 1m25s
CI / test (pull_request) Failing after 1m34s
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
Replace GitHub Container Registry with Gitea's built-in container registry.
- REGISTRY env var: ghcr.io -> git.farh.net
- All 4 build-and-push jobs: replace GHCR login with Gitea registry login
using cs_carl + GITEA_TOKEN (token already required for infra checkout)
- deploy-dev/deploy-uat: update kustomize image refs to git.farh.net/*
- Also fix legacy api/.gitea/workflows/ci.yml (non-executing nested file)
Required secrets drop from 5 to 3: DOCKERHUB_USERNAME, DOCKERHUB_TOKEN,
GITEA_TOKEN. GHCR_USERNAME and GHCR_TOKEN no longer needed.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-23 14:20:38 +00:00
Savannah Savings
6b6a50b9ec
Merge pull request 'Promote dev → uat: .gitea/workflows migration [CAR-934]' ( #261 ) from dev into uat
...
CI / lint (push) Successful in 14s
CI / test (push) Successful in 12s
CI / audit (push) Failing after 10s
CI / e2e (push) Successful in 39s
CI / build-and-push-receiptwitness (push) Failing after 8s
CI / build-and-push-api (push) Failing after 7s
CI / build-and-push-auth (push) Failing after 7s
CI / build-and-push (push) Failing after 8s
CI / deploy-dev (push) Has been skipped
CI / deploy-uat (push) Failing after 42s
CI / lighthouse (push) Failing after 17m22s
Promote dev → uat: .gitea/workflows migration [CAR-934]
cc @cpfarhood
2026-05-21 19:19:40 +00:00
Savannah Savings
4797f07af9
Merge pull request 'ci: move .github/workflows to .gitea/workflows [CAR-900]' ( #259 ) from barcode-betty/move-workflows-to-gitea into dev
...
CI / build-and-push-api (push) Failing after 7s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / lint (push) Successful in 13s
CI / test (pull_request) Successful in 11s
CI / lint (pull_request) Successful in 13s
CI / e2e (pull_request) Successful in 41s
CI / e2e (push) Successful in 38s
CI / deploy-dev (pull_request) Has been skipped
CI / test (push) Successful in 12s
CI / audit (push) Failing after 11s
CI / audit (pull_request) Failing after 11s
CI / build-and-push-receiptwitness (push) Failing after 7s
CI / build-and-push-auth (push) Failing after 7s
CI / build-and-push-api (pull_request) Has been skipped
CI / lighthouse (push) Failing after 1m17s
CI / build-and-push (pull_request) Has been skipped
CI / build-and-push (push) Failing after 11s
CI / deploy-dev (push) Failing after 34s
CI / lighthouse (pull_request) Failing after 1m13s
CI / deploy-uat (push) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
Merge PR #259 : ci: move .github/workflows to .gitea/workflows [CAR-897]
QA-approved. CTO merge to dev.
cc @cpfarhood
2026-05-21 19:19:20 +00:00
Flea Flicker
96331c9fa7
Move .github/workflows to .gitea/workflows
...
CI / test (pull_request) Successful in 13s
CI / lint (pull_request) Successful in 14s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / audit (pull_request) Failing after 10s
CI / e2e (pull_request) Successful in 39s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m12s
- Relocate all CI workflows from .github/workflows/ to .gitea/workflows/
- Root: .github/workflows/ci.yml -> .gitea/workflows/ci.yml
- api/: api/.github/workflows/ci.yml -> api/.gitea/workflows/ci.yml
- common/: common/.github/workflows/ci.yml -> common/.gitea/workflows/ci.yml
- Gitea uses .gitea/workflows/ for CI configuration
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-21 11:59:35 +00:00
Savannah Savings
a4e0b664e1
Merge pull request 'fix: use GHCR_USERNAME and GHCR_TOKEN for GHCR login in Gitea Actions' ( #258 ) from betty/fix-gitea-ci-secrets into dev
CI / audit (push) Failing after 11s
CI / test (push) Successful in 14s
CI / lint (push) Successful in 15s
CI / build-and-push-receiptwitness (push) Failing after 8s
CI / build-and-push-api (push) Failing after 8s
CI / build-and-push-auth (push) Failing after 8s
CI / e2e (push) Successful in 39s
CI / build-and-push (push) Failing after 8s
CI / deploy-uat (push) Has been skipped
CI / lighthouse (push) Failing after 1m16s
CI / deploy-dev (push) Failing after 43s
2026-05-21 06:21:55 +00:00
Flea Flicker
f4bbddd0dd
fix: use GHCR_USERNAME and GHCR_TOKEN for GHCR login in Gitea Actions
...
CI / audit (pull_request) Failing after 11s
CI / test (pull_request) Successful in 13s
CI / lint (pull_request) Successful in 14s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 40s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m11s
Gitea's GITHUB_TOKEN authenticates against git.farh.net, not ghcr.io.
Use explicit GHCR_USERNAME and GHCR_TOKEN secrets instead.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-21 05:25:36 +00:00
Savannah Savings
7c021c4eb5
Merge pull request 'chore: promote dev to uat - Gitea Actions workflow conversion' ( #254 ) from dev into uat
CI / test (push) Successful in 13s
CI / lint (push) Successful in 14s
CI / audit (push) Failing after 10s
CI / build-and-push-receiptwitness (push) Failing after 7s
CI / build-and-push-api (push) Failing after 7s
CI / build-and-push-auth (push) Failing after 8s
CI / e2e (push) Successful in 42s
CI / build-and-push (push) Failing after 8s
CI / deploy-dev (push) Has been skipped
CI / deploy-uat (push) Failing after 23s
CI / lighthouse (push) Failing after 1m16s
2026-05-21 04:23:11 +00:00
Savannah Savings
5a97290356
Merge pull request 'ci: convert GitHub Actions to Gitea Actions (ubuntu-latest)' ( #253 ) from betty/car-869-gitea-actions-cartsnitch into dev
CI / e2e (push) Successful in 41s
CI / lighthouse (push) Failing after 1m15s
CI / test (pull_request) Successful in 11s
CI / build-and-push-auth (push) Failing after 2m6s
CI / deploy-uat (push) Has been skipped
CI / audit (pull_request) Failing after 10s
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-receiptwitness (push) Failing after 2m3s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / build-and-push-api (push) Failing after 2m4s
CI / audit (push) Failing after 10s
CI / test (push) Successful in 12s
CI / lint (push) Successful in 13s
CI / lint (pull_request) Successful in 13s
CI / build-and-push (push) Failing after 6s
CI / deploy-uat (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 40s
CI / deploy-dev (push) Failing after 36s
CI / lighthouse (pull_request) Failing after 1m17s
2026-05-21 04:22:43 +00:00
Flea Flicker
32495b150b
ci: convert GitHub Actions to Gitea Actions (ubuntu-latest)
...
CI / audit (pull_request) Failing after 11s
CI / test (pull_request) Successful in 13s
CI / lint (pull_request) Successful in 14s
CI / build-and-push-receiptwitness (pull_request) Has been skipped
CI / build-and-push-api (pull_request) Has been skipped
CI / build-and-push-auth (pull_request) Has been skipped
CI / e2e (pull_request) Successful in 40s
CI / build-and-push (pull_request) Has been skipped
CI / deploy-dev (pull_request) Has been skipped
CI / deploy-uat (pull_request) Has been skipped
CI / lighthouse (pull_request) Failing after 1m13s
- Replace all runs-on: runners-cartsnitch with ubuntu-latest
- Remove SARIF upload steps (no Gitea Security tab)
- Replace GitHub App token with secrets.GITEA_TOKEN in deploy-dev and deploy-uat
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-21 03:54:18 +00:00
savannah-savings-cto[bot]
a5404dc824
promote: dev → uat (fix auth tsc build) ( #252 )
...
promote: dev → uat (fix auth tsc build)
2026-05-05 11:19:44 +00:00
savannah-savings-cto[bot]
b39280ee2a
fix(auth): exclude test files from tsc build ( #251 )
...
fix(auth): exclude test files from tsc build
2026-05-05 11:19:19 +00:00
Chris Farhood
752d7ed3d0
fix(auth): exclude test files from tsc compilation
...
Exclude src/__tests__ from tsconfig to prevent test files from being
compiled during Docker build. Fixes build-and-push-auth CI failure.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-05 11:11:53 +00:00
savannah-savings-cto[bot]
618da593a6
Merge pull request #250 from cartsnitch/dev
...
ci: promote dev → uat (auth CI pipeline)
2026-05-05 10:56:35 +00:00
savannah-savings-cto[bot]
1f317a0616
Merge pull request #249 from cartsnitch/betty/car-843-auth-ci-pipeline
...
ci: add auth service build/deploy to CI pipeline
2026-05-05 10:56:19 +00:00
Chris Farhood
912239a97b
ci: add auth service build/deploy to CI pipeline
...
Add build-and-push-auth job and update deploy-dev/uat to include auth image.
- Add AUTH_IMAGE_NAME env var
- Add build-and-push-auth job (modeled on build-and-push-api)
- Add build-and-push-auth to deploy-dev and deploy-uat needs
- Add auth image tag determination and update steps in both deploy jobs
- Update commit messages to include auth
2026-05-05 06:44:15 +00:00
coupon-carl-ceo[bot]
e3ed19f98c
release: promote uat → main (seed tooling CAR-812 + auth health)
...
CI / test (pull_request) Has been cancelled
CI / audit (pull_request) Has been cancelled
CI / e2e (pull_request) Has been cancelled
CI / build-and-push-receiptwitness (pull_request) Has been cancelled
CI / deploy-uat (pull_request) Has been cancelled
CI / lint (pull_request) Has been cancelled
CI / lighthouse (pull_request) Has been cancelled
CI / build-and-push (pull_request) Has been cancelled
CI / build-and-push-api (pull_request) Has been cancelled
CI / deploy-dev (pull_request) Has been cancelled
UAT PASS (Deal Dottie, 2026-05-04) + Security PASS (Stockboy Steve, 2026-05-04)
Merged with admin privileges due to 1-commit divergence (README/UI-only release commit from PR #245 with no file overlap with uat changes). No functional conflict.
Refs: CAR-842, CAR-812
v2026.05.04
2026-05-04 21:55:13 +00:00
savannah-savings-cto[bot]
e54736d900
chore: promote dev → uat (seed tooling, CAR-812) ( #247 )
...
chore: promote dev → uat (seed tooling, CAR-812)
2026-05-04 21:44:34 +00:00
savannah-savings-cto[bot]
59850c0cb4
feat: parameterize seed tooling for UAT + document UAT receipt-submission path ( #243 )
...
feat: parameterize seed tooling for UAT + document UAT receipt-submission path
2026-05-04 21:43:56 +00:00
Chris Farhood
757444e582
docs: clarify UAT seed requirements when kubectl unavailable
...
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
Chris Farhood
00fe9f14ea
chore: drop out-of-scope auth/vitest/e2e/Login/Register changes
...
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
Chris Farhood
ff1e1351f1
fix(CAR-812): correct receipt email format and --env flag parser
...
- docs: fix email address format to receipts+<token>@receipts.cartsnitch.com
(per Settings → Receipt Email UI, not the old farh.net domain format)
- docs: fix UI section label from 'Account' to 'Receipt Email'
- scripts/seed-env.sh: fix --env flag parser when called as './seed-env.sh --env uat'
positional form was already correct; flag form was consuming --env as ENV value
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
Chris Farhood
d57a90ed59
feat: parameterize seed tooling for UAT + document UAT receipt-submission path
...
- Add scripts/seed-env.sh with --env dev|uat argument, replacing hardcoded namespace
- Keep scripts/seed-dev.sh as one-line wrapper calling seed-env.sh dev
- Add scripts/seed-env-job.yaml with __ENV__ placeholder for namespace/label
- Add scripts/apply-seed-job.sh <env> helper using sed substitution
- Keep scripts/seed-dev-job.yaml as unchanged backward-compat copy
- Add docs/uat-receipt-submission.md documenting the inbound email receipt path for UAT
Refs: CAR-812, CAR-808
2026-05-04 21:29:20 +00:00
Chris Farhood
7e9f7c0ef9
fix(auth): support /auth/health path and align db response with tests
...
- Add /auth/health as additional health check route (Envoy forwards full path)
- Change db status 'connected' to 'reachable' to match health.test.ts
- Only pass /auth/* routes to Better-Auth handler to prevent 404 on unknown routes
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
Chris Farhood
d15893b984
chore: exclude auth tests from root vitest
...
Auth package has its own test runner (node --test) configured.
Exclude auth directory from root vitest to prevent no-test-suite error.
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
Chris Farhood
48136a6d8f
test(auth): add health endpoint unit tests
...
- Add node:test suite for auth health endpoint covering:
- 200 with db=reachable when pool.connect succeeds
- 503 with db=unreachable when pool.connect throws
- 503 with db=unreachable when query times out
- Add test script to auth/package.json
- Merge dev to resolve 3-commit divergence
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
Barcode Betty
e120aeee2f
fix: restore Resend email verification and update health check timeout
...
- Restore import { Resend } from 'resend'
- Restore resend and fromEmail constants
- Restore emailVerification block with sendOnSignUp, autoSignInAfterVerification, and sendVerificationEmail
- Change health endpoint timeout from 2s to 3s
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
Paperclip
d4e13ef286
fix(auth): add DB connectivity check to health endpoint
...
- Export pool from auth.ts for use in health check
- Replace static ok response with SELECT 1 query
- Return 503 with db=unreachable on failure or timeout
Co-Authored-By: Paperclip <noreply@paperclip.ing >
2026-05-04 21:29:20 +00:00
savannah-savings-cto[bot]
40abf64888
chore: promote dev → uat (auth health routing fix) ( #246 )
...
chore: promote dev → uat (auth health routing fix)
2026-05-04 21:17:31 +00:00