Commit bfdfa55
authored
fix: pass full context to
* fix: pass full context to `Ash.load!` in cascade changes
The `Ash.load!` calls in `cascade_destroy` and `cascade_update` were
only passing `tenant: tenant`, missing the actor and other context
options. This caused policy failures when policies require an actor.
Use `Ash.Context.to_opts(context)` to pass all relevant context options
(actor, tenant, tracer, context, authorize?), consistent with how
`context_opts` is already passed to `Ash.bulk_destroy!`/`Ash.bulk_update!`
in the same code path.
Closes #2536
* fix: use scope option instead of to_opts for Ash.load! in cascade changes
* fix: avoid shadowing context variable in cascade changes
Rename the rebound `context` variable to `action_context` to preserve
the original context parameter containing tenant, actor, and tracer.
This ensures `scope: context` in `Ash.load!` receives the full context.
* fix: remove `authorize?: false` from cascade `Ash.load!` calls
Authorization was intentionally removed in #1948 in favour of
`accessing_from` policies. Passing `authorize?: false` here would
bypass that intent.Ash.load! in cascade changes (#2537)1 parent c5088a8 commit bfdfa55
File tree
2 files changed
+14
-14
lines changed- lib/ash/resource/change
2 files changed
+14
-14
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
283 | 283 | | |
284 | 284 | | |
285 | 285 | | |
286 | | - | |
| 286 | + | |
287 | 287 | | |
288 | 288 | | |
289 | 289 | | |
| |||
296 | 296 | | |
297 | 297 | | |
298 | 298 | | |
299 | | - | |
| 299 | + | |
300 | 300 | | |
301 | 301 | | |
302 | 302 | | |
| |||
306 | 306 | | |
307 | 307 | | |
308 | 308 | | |
309 | | - | |
310 | | - | |
| 309 | + | |
| 310 | + | |
311 | 311 | | |
312 | 312 | | |
313 | 313 | | |
| |||
346 | 346 | | |
347 | 347 | | |
348 | 348 | | |
349 | | - | |
| 349 | + | |
350 | 350 | | |
351 | 351 | | |
352 | 352 | | |
| |||
359 | 359 | | |
360 | 360 | | |
361 | 361 | | |
362 | | - | |
363 | | - | |
| 362 | + | |
| 363 | + | |
364 | 364 | | |
365 | 365 | | |
366 | 366 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
188 | 188 | | |
189 | 189 | | |
190 | 190 | | |
191 | | - | |
| 191 | + | |
192 | 192 | | |
193 | 193 | | |
194 | 194 | | |
| |||
214 | 214 | | |
215 | 215 | | |
216 | 216 | | |
217 | | - | |
| 217 | + | |
218 | 218 | | |
219 | 219 | | |
220 | 220 | | |
| |||
224 | 224 | | |
225 | 225 | | |
226 | 226 | | |
227 | | - | |
228 | | - | |
| 227 | + | |
| 228 | + | |
229 | 229 | | |
230 | 230 | | |
231 | 231 | | |
| |||
260 | 260 | | |
261 | 261 | | |
262 | 262 | | |
263 | | - | |
| 263 | + | |
264 | 264 | | |
265 | 265 | | |
266 | 266 | | |
| |||
273 | 273 | | |
274 | 274 | | |
275 | 275 | | |
276 | | - | |
277 | | - | |
| 276 | + | |
| 277 | + | |
278 | 278 | | |
279 | 279 | | |
280 | 280 | | |
| |||
0 commit comments