Commit 3020241
committed
Restrict RemoveLabelsFromLabelsetMutation to creator-only
The resolver previously fetched the labelset with `Q(creator=user) | Q(is_public=True)`
and removed the requested labels with no further authorization check, allowing any
authenticated user to mutate another user's public labelset. is_public exposes a
labelset for use, not for mutation, and the companion CreateLabelForLabelsetMutation
is already creator-only -- so the asymmetry was a real bug, not a design choice.
Tightened the lookup to pk + creator, dropped the now-unused Q import, and inverted
the regression test that previously pinned the permissive behavior.1 parent 2d7033f commit 3020241
3 files changed
Lines changed: 12 additions & 10 deletions
File tree
- config/graphql
- opencontractserver/tests
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
12 | 13 | | |
13 | 14 | | |
14 | 15 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | | - | |
12 | 11 | | |
13 | 12 | | |
14 | 13 | | |
| |||
290 | 289 | | |
291 | 290 | | |
292 | 291 | | |
293 | | - | |
294 | | - | |
| 292 | + | |
295 | 293 | | |
296 | 294 | | |
297 | 295 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
171 | 171 | | |
172 | 172 | | |
173 | 173 | | |
174 | | - | |
175 | | - | |
| 174 | + | |
| 175 | + | |
176 | 176 | | |
177 | | - | |
178 | | - | |
179 | | - | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
180 | 180 | | |
181 | 181 | | |
182 | 182 | | |
| |||
191 | 191 | | |
192 | 192 | | |
193 | 193 | | |
194 | | - | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
195 | 198 | | |
196 | | - | |
| 199 | + | |
0 commit comments