Commit 33f0dd3
feat(BA-5829): add AppConfigFragment DataLoader for N+1 batching
Follows the `audit_log_loader` / `prometheus_query_preset_category_loader`
pattern — adapter exposes `batch_load_by_ids(ids)` which goes through
the `SearchAppConfigFragments` action path with an id-filter condition,
and `DataLoaders.app_config_fragment_loader` wraps it for use from
GQL resolvers via `info.context.data_loaders.app_config_fragment_loader`.
Cross-scope `admin_search` is used instead of the scope-bound `search`
action because DataLoader batches span scopes; authorization is already
enforced at the parent resolver before the loader is ever invoked
(same stance as other loaders in the registry).
Adds:
- `AppConfigFragmentAdapter.batch_load_by_ids` (adapter-level batching
via `AppConfigFragmentConditions.by_ids` + `OffsetPagination(len(ids))`).
- `DataLoaders.app_config_fragment_loader` cached-property.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>1 parent c5ec5a5 commit 33f0dd3
2 files changed
Lines changed: 53 additions & 1 deletion
Lines changed: 34 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
2 | 2 | | |
3 | 3 | | |
4 | 4 | | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
5 | 8 | | |
6 | 9 | | |
7 | 10 | | |
| |||
36 | 39 | | |
37 | 40 | | |
38 | 41 | | |
39 | | - | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
40 | 48 | | |
41 | 49 | | |
42 | 50 | | |
| |||
60 | 68 | | |
61 | 69 | | |
62 | 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 | + | |
63 | 96 | | |
64 | 97 | | |
65 | 98 | | |
| |||
Lines changed: 19 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
17 | 20 | | |
18 | 21 | | |
19 | 22 | | |
| |||
113 | 116 | | |
114 | 117 | | |
115 | 118 | | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
116 | 135 | | |
117 | 136 | | |
118 | 137 | | |
| |||
0 commit comments