Commit 6b84929
committed
CS-11264: route _realm-auth through reconciler.lookupOrMount
Pre-Phase-3 (CS-10894), every realm in the registry was eagerly
mounted at boot, so iterating the in-memory `realms[]` to resolve
a permission row's URL was equivalent to consulting the registry.
After Phase 3 only `pinned=true` rows mount at boot; non-pinned
(source / published) rows wait for a request-path
`reconciler.lookupOrMount()` to bring them in. `_realm-auth` was
left calling `allRealms.find(...)` directly — so after a
realm-server restart, an owner's first `boxel-cli` push/publish
fails with `No realm token available` because the auth handler
silently skips the permission row whose URL isn't yet in
`realms[]`. The matching `realm_user_permissions` row is intact;
the gap is purely in this handler's view of mounted realms.
Restore the pre-Phase-3 contract that calling `/_realm-auth` is
sufficient to interact with any realm the user has permissions on
by routing through `reconciler.lookupOrMount(realmUrl)`. Pinned
rows resolve via the `mounted` fast-path (O(1)); non-pinned rows
pay one cold-mount cost on first hit, the same cost any other
first request would pay. Mount failures Sentry-capture-and-skip,
mirroring the existing `ensureSessionRoom` failure handling.
Adds a `testingOnlyEvictRealmFromRealmsList(url)` shim on
`RealmServer` so the regression test can simulate the post-
restart "row in DB, realm not yet in this process's realms[]"
state without re-running disk mount / matrix login.
Regression test in `realm-auth-test.ts` evicts the test realm
from `realms[]`, hits `/_realm-auth`, and asserts a JWT is
issued. Confirmed it fails on the pre-fix code path and passes
on the fix.1 parent 2996098 commit 6b84929
3 files changed
Lines changed: 81 additions & 4 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
14 | 15 | | |
15 | 16 | | |
16 | 17 | | |
17 | | - | |
| 18 | + | |
18 | 19 | | |
19 | 20 | | |
20 | 21 | | |
21 | | - | |
22 | 22 | | |
23 | 23 | | |
24 | 24 | | |
| |||
42 | 42 | | |
43 | 43 | | |
44 | 44 | | |
45 | | - | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
46 | 57 | | |
47 | 58 | | |
48 | 59 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
543 | 543 | | |
544 | 544 | | |
545 | 545 | | |
| 546 | + | |
| 547 | + | |
| 548 | + | |
| 549 | + | |
| 550 | + | |
| 551 | + | |
| 552 | + | |
| 553 | + | |
| 554 | + | |
| 555 | + | |
| 556 | + | |
| 557 | + | |
| 558 | + | |
546 | 559 | | |
547 | 560 | | |
548 | 561 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| 16 | + | |
16 | 17 | | |
17 | 18 | | |
18 | 19 | | |
19 | 20 | | |
20 | 21 | | |
| 22 | + | |
21 | 23 | | |
22 | 24 | | |
23 | 25 | | |
| |||
27 | 29 | | |
28 | 30 | | |
29 | 31 | | |
30 | | - | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
31 | 37 | | |
32 | 38 | | |
| 39 | + | |
33 | 40 | | |
34 | 41 | | |
35 | 42 | | |
| |||
86 | 93 | | |
87 | 94 | | |
88 | 95 | | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
89 | 142 | | |
90 | 143 | | |
0 commit comments