Commit 37deb8f
committed
fix(perms): scope-aware filter sanitisation for translation sub-fields (I-1)
Previously `sanitizeFilter` only checked the root field of each filter
clause, so a search/filter like
{ translations: { _some: { description: { _icontains: 'foo' } } } }
slipped through unchanged when the user had read on `translations` but
not on the `description` sub-field of the junction collection. The API
then rejected the query with 403 and the layout showed an empty table —
exactly the symptom Bug E was supposed to eliminate.
Fix: extend `sanitizeFilter` with a `nestedScopes` option mapping
parent-field-name → nested-collection-name. The walker now:
- treats _some / _none / _every as relation-match operators that
recurse with the same scope (we are already inside the relation)
- recurses into the value of a configured nested-scope field with
the nested collection set as scope
- calls canRead(field, scope) so the caller can dispatch to the
right collection's permissions
Caller in super-table.vue passes
{ nestedScopes: { translations: <junction collection> } }
and uses (field, scope) => permissions.canRead(scope ?? collection, field).
Tests:
- 6 baseline tests still pass (canRead's optional second arg is
backward-compatible).
- 7 new tests cover the nested cases: _some/_none/_every, mixed
siblings (one allowed one denied), translation branch dropped
inside _or, no-options backward-compat, and the trivial case
where filter never touches the nested scope.
Live verification: as the test user, with description read removed
from the junction collection and the bookmark filter set to
{translations: {_some: {description: {_icontains: 'test'}}}}, the
items query is now sent without any filter clause and returns 200 OK
with all three items, instead of 403 and an empty table.
Surfaced by code review on PR #57.1 parent 7c9826f commit 37deb8f
3 files changed
Lines changed: 180 additions & 14 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
921 | 921 | | |
922 | 922 | | |
923 | 923 | | |
924 | | - | |
| 924 | + | |
| 925 | + | |
| 926 | + | |
| 927 | + | |
| 928 | + | |
| 929 | + | |
| 930 | + | |
| 931 | + | |
| 932 | + | |
| 933 | + | |
| 934 | + | |
| 935 | + | |
| 936 | + | |
| 937 | + | |
| 938 | + | |
925 | 939 | | |
926 | 940 | | |
927 | 941 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
8 | 23 | | |
| 24 | + | |
9 | 25 | | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
10 | 40 | | |
11 | 41 | | |
12 | | - | |
| 42 | + | |
| 43 | + | |
13 | 44 | | |
14 | 45 | | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
15 | 54 | | |
16 | | - | |
| 55 | + | |
17 | 56 | | |
18 | 57 | | |
19 | 58 | | |
20 | | - | |
21 | | - | |
22 | | - | |
23 | | - | |
24 | | - | |
25 | | - | |
26 | | - | |
27 | | - | |
28 | | - | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
29 | 62 | | |
30 | 63 | | |
31 | 64 | | |
32 | 65 | | |
| 66 | + | |
33 | 67 | | |
34 | | - | |
| 68 | + | |
35 | 69 | | |
36 | 70 | | |
37 | 71 | | |
38 | 72 | | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
39 | 89 | | |
40 | | - | |
| 90 | + | |
41 | 91 | | |
42 | 92 | | |
43 | 93 | | |
44 | 94 | | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
45 | 111 | | |
46 | 112 | | |
47 | 113 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
43 | 43 | | |
44 | 44 | | |
45 | 45 | | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 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 | + | |
0 commit comments