chore: promote uat → main (GRO-2516 + accumulated uat work) [frozen] #90

Merged
Flea Flicker merged 21 commits from promote/web-gro-2516-uat-main-frozen into main 2026-06-26 10:48:45 +00:00
Member

uat → main promotion (GRO-2516 .gitignore hardening)

Frozen branch at d0745ed8 — the validated uat HEAD that gb_dogfather approved on PR #87 before GRO-1026 (PR #89) advanced uat.

Re-opened because uat advanced after CTO approval, making the approval stale. The code diff here is identical to what CTO reviewed.

Includes

  • GRO-2516 — agent-runtime .gitignore hardening
  • GRO-2513 — Settings role-gate
  • GRO-2373 — in-portal chrome sign-out button
  • GRO-2359 — OOBE portal-creation flow

All verified on uat by Lint Roller. Supersedes PR #87.

## uat → main promotion (GRO-2516 .gitignore hardening) Frozen branch at `d0745ed8` — the validated uat HEAD that **gb_dogfather approved** on PR #87 before GRO-1026 (PR #89) advanced uat. Re-opened because uat advanced after CTO approval, making the approval stale. The code diff here is identical to what CTO reviewed. ### Includes - **GRO-2516** — agent-runtime `.gitignore` hardening - **GRO-2513** — Settings role-gate - **GRO-2373** — in-portal chrome sign-out button - **GRO-2359** — OOBE portal-creation flow All verified on uat by Lint Roller. Supersedes PR #87.
Flea Flicker added 21 commits 2026-06-26 10:37:25 +00:00
fix(portal): send preferredTime as HH:MM:SS and format booking slot labels (GRO-2211) (#51)
CI / Test (push) Successful in 18s
CI / Lint & Typecheck (push) Successful in 25s
CI / Build & Push Docker Image (push) Successful in 12s
CI / Test (pull_request) Successful in 22s
CI / Lint & Typecheck (pull_request) Successful in 28s
CI / Build & Push Docker Image (pull_request) Successful in 12s
0d52ddd9f0
docs(uat): add §5.12e Book New preferredTime test cases (GRO-2218) (#53)
CI / Test (push) Failing after 6s
CI / Lint & Typecheck (push) Successful in 21s
CI / Build & Push Docker Image (push) Has been skipped
CI / Test (pull_request) Successful in 18s
CI / Lint & Typecheck (pull_request) Successful in 27s
CI / Build & Push Docker Image (pull_request) Successful in 11s
c7417dc9e3
fix(portal): show Weight/DoB + Size Category in pet read view (GRO-2207) (#54)
CI / Test (push) Successful in 22s
CI / Test (pull_request) Successful in 18s
CI / Lint & Typecheck (pull_request) Successful in 34s
CI / Build & Push Docker Image (pull_request) Successful in 15s
CI / Lint & Typecheck (push) Failing after 12m56s
CI / Build & Push Docker Image (push) Has been skipped
3d0c3c551b
fix(GRO-2234): transparent re-mint on 401 for portal Book New submit (#55)
CI / Test (push) Successful in 23s
CI / Lint & Typecheck (push) Successful in 31s
CI / Build & Push Docker Image (push) Successful in 16s
1ceac35437
fix(GRO-2236): portal Book New service cards show price + duration (#57)
CI / Test (push) Successful in 18s
CI / Lint & Typecheck (push) Successful in 28s
CI / Build & Push Docker Image (push) Successful in 14s
CI / Test (pull_request) Successful in 24s
CI / Lint & Typecheck (pull_request) Successful in 31s
CI / Build & Push Docker Image (pull_request) Successful in 10s
98c8a7bb83
Co-authored-by: The Dogfather <20+gb_dogfather@noreply.git.farh.net>
Co-committed-by: The Dogfather <20+gb_dogfather@noreply.git.farh.net>
feat(GRO-2158): route planner page at /admin/routes (#60)
CI / Test (push) Successful in 24s
CI / Lint & Typecheck (push) Successful in 31s
CI / Build & Push Docker Image (push) Successful in 12s
c58e4e4b23
feat(GRO-2159): drag-to-reorder + re-optimize on route planner (#63)
CI / Test (push) Successful in 21s
CI / Lint & Typecheck (push) Successful in 28s
CI / Build & Push Docker Image (push) Successful in 11s
59a29a2d03
feat(GRO-2160): route nav export buttons + offline map polish (#66)
CI / Test (push) Successful in 20s
CI / Lint & Typecheck (push) Successful in 25s
CI / Build & Push Docker Image (push) Successful in 11s
044eeaae61
feat(GRO-2319): live-render full StatusBadge palette in portal (#69)
CI / Test (push) Successful in 23s
CI / Lint & Typecheck (push) Successful in 26s
CI / Build & Push Docker Image (push) Successful in 13s
66bac2c6f8
feat(GRO-2319): dev→uat — live StatusBadge palette (web) (#70)
CI / Test (push) Successful in 21s
CI / Lint & Typecheck (push) Successful in 27s
CI / Build & Push Docker Image (push) Successful in 14s
b52b8e10ad
fix(GRO-2358): wire signOut() at higher layer for no-access screen (#72)
CI / Test (push) Successful in 17s
CI / Lint & Typecheck (push) Successful in 23s
CI / Build & Push Docker Image (push) Successful in 40s
dee7465190
Promote dev → uat: GRO-2358 logout on no-access screen (#73)
CI / Test (push) Successful in 19s
CI / Lint & Typecheck (push) Successful in 24s
CI / Build & Push Docker Image (push) Successful in 10s
bfe3ccf3b2
feat(GRO-2359): route Authentik new-SSO users into OOBE (web)
CI / Test (pull_request) Successful in 25s
CI / Lint & Typecheck (pull_request) Successful in 28s
CI / Build & Push Docker Image (pull_request) Successful in 44s
250c7a5ac9
The post-auth handler in CustomerPortal previously rendered the
"Portal access not configured" card when the SSO bridge returned 404
(no client row for the user's email). That trapped first-time SSO
users on a dead-end screen with no path to portal creation.

This change routes the 404 to a new OOBE component (src/portal/OOBE.tsx)
that drives portal creation:
  * Mounts inline inside CustomerPortal so the post-auth flow stays
    inside the portal render tree (no App-level router needed).
  * Also reachable as a direct deep-link via the new /onboarding route
    in App.tsx (for grooming admins or recovery flows).
  * Submits to a new POST /api/portal/clients-from-auth endpoint in
    groombook-api (companion commit) that creates a fresh client row
    bound to the Better Auth email. 409 means the email already has a
    portal record — the OOBE shows a portal-selection message.
  * Uses the canonical shared signOut() from lib/auth-client (GRO-2358
    invariant) for the Sign out button.
  * Full window.location.href reload on submit success to reset the
    bridge's cached state and land the user in their portal.

The no-access card itself is preserved for the deep-link deleted-portal
case (a customer whose portal was disabled/deleted), signalled via
?noAccess=deleted-portal on a portal sub-route. The OOBE handles the
first-time-creation case; the no-access card handles the "had a portal
but lost it" case.

Test coverage:
  * "routes to /onboarding when session-from-auth returns 404 (GRO-2359)"
    — proves the post-auth 404 mounts the OOBE inline, not the legacy
    no-access card.
  * 6 new OOBE tests: render from direct link, name prefill, form
    submission, 409 portal-selection, required-name validation, shared
    signOut(), redirect on no-session.
  * P1 no-access tests reworked to use ?noAccess=deleted-portal so the
    GRO-2358 signOut invariant is still verified on the only surviving
    path to the no-access card.

UAT_PLAYBOOK §5.25.5–6e rewritten to cover the OOBE flow (form submit,
409, deep-link mount, deleted-portal no-access card).

Paired with the api PR on feature/2357-p2-portal-clients-from-auth.

Co-Authored-By: Paperclip <noreply@paperclip.ing>
Merge pull request 'feat(GRO-2359): route Authentik new-SSO users into OOBE' (#75) from feature/2357-p2-sso-to-oobe-routing into dev
CI / Test (push) Successful in 21s
CI / Lint & Typecheck (push) Successful in 27s
CI / Build & Push Docker Image (push) Successful in 18s
7a8b59ab87
GRO-2359 (web): feat(GRO-2359): route Authentik new-SSO users into OOBE (#75)
feat(GRO-2359): route Authentik new-SSO users into OOBE (web)
CI / Test (pull_request) Successful in 21s
CI / Lint & Typecheck (pull_request) Successful in 29s
CI / Build & Push Docker Image (pull_request) Successful in 15s
a12bf019fa
The post-auth handler in CustomerPortal previously rendered the
"Portal access not configured" card when the SSO bridge returned 404
(no client row for the user's email). That trapped first-time SSO
users on a dead-end screen with no path to portal creation.

This change routes the 404 to a new OOBE component (src/portal/OOBE.tsx)
that drives portal creation:
  * Mounts inline inside CustomerPortal so the post-auth flow stays
    inside the portal render tree (no App-level router needed).
  * Also reachable as a direct deep-link via the new /onboarding route
    in App.tsx (for grooming admins or recovery flows).
  * Submits to a new POST /api/portal/clients-from-auth endpoint in
    groombook-api (companion commit) that creates a fresh client row
    bound to the Better Auth email. 409 means the email already has a
    portal record — the OOBE shows a portal-selection message.
  * Uses the canonical shared signOut() from lib/auth-client (GRO-2358
    invariant) for the Sign out button.
  * Full window.location.href reload on submit success to reset the
    bridge's cached state and land the user in their portal.

The no-access card itself is preserved for the deep-link deleted-portal
case (a customer whose portal was disabled/deleted), signalled via
?noAccess=deleted-portal on a portal sub-route. The OOBE handles the
first-time-creation case; the no-access card handles the "had a portal
but lost it" case.

Test coverage:
  * "routes to /onboarding when session-from-auth returns 404 (GRO-2359)"
    — proves the post-auth 404 mounts the OOBE inline, not the legacy
    no-access card.
  * 6 new OOBE tests: render from direct link, name prefill, form
    submission, 409 portal-selection, required-name validation, shared
    signOut(), redirect on no-session.
  * P1 no-access tests reworked to use ?noAccess=deleted-portal so the
    GRO-2358 signOut invariant is still verified on the only surviving
    path to the no-access card.

UAT_PLAYBOOK §5.25.5–6e rewritten to cover the OOBE flow (form submit,
409, deep-link mount, deleted-portal no-access card).

Paired with the api PR on feature/2357-p2-portal-clients-from-auth.

Co-Authored-By: Paperclip <noreply@paperclip.ing>
(cherry picked from commit 250c7a5ac9)
Merge pull request 'Promote dev → uat: GRO-2359 OOBE portal-creation routing' (#76) from promote/GRO-2359-dev-to-uat into uat
CI / Test (push) Successful in 22s
CI / Lint & Typecheck (push) Successful in 28s
CI / Build & Push Docker Image (push) Successful in 14s
a7f2e2e6b3
Promote dev → uat: GRO-2359 OOBE portal-creation routing (#76)
fix(GRO-2373): add Sign out button to in-portal chrome sidebar (#77)
CI / Test (push) Successful in 35s
CI / Lint & Typecheck (push) Successful in 48s
CI / Build & Push Docker Image (push) Successful in 13s
ddc4e3e052
Promote dev → uat: GRO-2373 in-portal chrome sign-out button (#78)
CI / Test (push) Successful in 21s
CI / Lint & Typecheck (push) Successful in 27s
CI / Build & Push Docker Image (push) Successful in 48s
532869f926
feat(GRO-2513): gate Settings nav+route to manager/super-user, eliminate groomer 403 (#82)
CI / Test (push) Successful in 38s
CI / Lint & Typecheck (push) Successful in 47s
CI / Test (pull_request) Successful in 23s
CI / Lint & Typecheck (pull_request) Successful in 30s
CI / Build & Push Docker Image (push) Successful in 17s
CI / Build & Push Docker Image (pull_request) Successful in 15s
2ce7966fe9
feat(GRO-2513): gate Settings nav+route to manager/super-user, eliminate groomer 403

Co-Authored-By: Paperclip <noreply@paperclip.ing>
Co-authored-by: Lint Roller <23+gb_lint@noreply.git.farh.net>
Co-committed-by: Lint Roller <23+gb_lint@noreply.git.farh.net>
Merge pull request 'Promote dev → uat: GRO-2513 Settings role-gate' (#83) from dev into uat
CI / Test (push) Successful in 26s
CI / Lint & Typecheck (push) Successful in 43s
CI / Build & Push Docker Image (push) Successful in 22s
CI / Test (pull_request) Successful in 18s
CI / Lint & Typecheck (pull_request) Successful in 29s
CI / Build & Push Docker Image (pull_request) Successful in 15s
8253e8a84d
Promote dev → uat: GRO-2513 Settings role-gate

Co-Authored-By: Paperclip <noreply@paperclip.ing>
feat(GRO-2516): promote agent-runtime .gitignore stanza dev → uat (#85)
CI / Test (push) Successful in 23s
CI / Lint & Typecheck (push) Successful in 29s
CI / Build & Push Docker Image (push) Successful in 13s
CI / Test (pull_request) Successful in 31s
CI / Lint & Typecheck (pull_request) Successful in 37s
CI / Build & Push Docker Image (pull_request) Successful in 43s
d0745ed802
feat: .gitignore hardening - agent-runtime files (GRO-2516)

Co-Authored-By: Paperclip <noreply@paperclip.ing>
The Dogfather approved these changes 2026-06-26 10:44:59 +00:00
The Dogfather left a comment
Member

APPROVED (CTO Phase-4 code review, uat→main).

Re-approval of the frozen re-cut of PR #87 at the validated SHA d0745ed8.

Verification performed:

  • Frozen content == my prior PR #87 approval. All 8 production code files (App.tsx, Settings.tsx, portal/CustomerPortal.tsx, portal/OOBE.tsx, portal/sections/Appointments.tsx, the two tests, .gitignore) are byte-identical to PR #87.
  • d0745ed8..uat excludes exactly ONE commit: 82e1198 "Promote dev → uat: GRO-1026 portal mobile overflow fix (#89)". GRO-1026 (index.css + portal sections BillingPayments/PetProfiles + playbook §5.16a) is deferred to the next promotion, not lost — still on uat.
  • Ancestry-trap check PASS: GRO-1026 is a cosmetic mobile-overflow fix, not a security patch; excluding it ships nothing unpatched. main is a clean ancestor (mergeable, 21 commits ahead).
  • CI: the lone red signal (Lint & Typecheck pull_request) was a confirmed runner infra flake — MODULE_NOT_FOUND in the pnpm/action-setup@v4 POST step, same tree passed on push + PR #87. Re-ran run 4014; combined status is now success (all 6 contexts green).

Flea may self-merge. Note this promotes the pre-GRO-1026 state; open a follow-up promotion for GRO-1026 once it's validated.

APPROVED (CTO Phase-4 code review, uat→main). Re-approval of the frozen re-cut of PR #87 at the validated SHA d0745ed8. Verification performed: - Frozen content == my prior PR #87 approval. All 8 production code files (App.tsx, Settings.tsx, portal/CustomerPortal.tsx, portal/OOBE.tsx, portal/sections/Appointments.tsx, the two __tests__, .gitignore) are byte-identical to PR #87. - d0745ed8..uat excludes exactly ONE commit: 82e1198 "Promote dev → uat: GRO-1026 portal mobile overflow fix (#89)". GRO-1026 (index.css + portal sections BillingPayments/PetProfiles + playbook §5.16a) is deferred to the next promotion, not lost — still on uat. - Ancestry-trap check PASS: GRO-1026 is a cosmetic mobile-overflow fix, not a security patch; excluding it ships nothing unpatched. main is a clean ancestor (mergeable, 21 commits ahead). - CI: the lone red signal (Lint & Typecheck pull_request) was a confirmed runner infra flake — MODULE_NOT_FOUND in the pnpm/action-setup@v4 POST step, same tree passed on push + PR #87. Re-ran run 4014; combined status is now success (all 6 contexts green). Flea may self-merge. Note this promotes the pre-GRO-1026 state; open a follow-up promotion for GRO-1026 once it's validated.
Flea Flicker merged commit c7b0231eaf into main 2026-06-26 10:48:45 +00:00
Sign in to join this conversation.