From 718f431e84e6a9d64fe8b28ecc6b522bfe7c5e5e Mon Sep 17 00:00:00 2001 From: Barnabas Jovanovics Date: Sun, 24 Nov 2024 18:55:22 +0100 Subject: [PATCH] fix: add opts to all Ash.load calls (#260) --- lib/ash_json_api/controllers/helpers.ex | 44 ++++++++++++++++++------- lib/ash_json_api/request.ex | 7 ++++ 2 files changed, 40 insertions(+), 11 deletions(-) diff --git a/lib/ash_json_api/controllers/helpers.ex b/lib/ash_json_api/controllers/helpers.ex index 86512ec..543a2c5 100644 --- a/lib/ash_json_api/controllers/helpers.ex +++ b/lib/ash_json_api/controllers/helpers.ex @@ -57,8 +57,13 @@ defmodule AshJsonApi.Controllers.Helpers do with {:ok, result} <- Ash.run_action(action_input), {:ok, result} <- - Ash.load(result, fields(request, request.resource), reuse_values?: true), - {:ok, result} <- Ash.load(result, request.includes_keyword) do + Ash.load( + result, + fields(request, request.resource), + Request.load_opts(request, reuse_values?: true) + ), + {:ok, result} <- + Ash.load(result, request.includes_keyword, Request.load_opts(request)) do Request.assign(request, :result, result) else {:error, error} -> @@ -222,11 +227,16 @@ defmodule AshJsonApi.Controllers.Helpers do with {:ok, result} <- Ash.run_action(action_input), {:ok, result} <- - Ash.load(result, fields(request, request.resource), reuse_values?: true), + Ash.load( + result, + fields(request, request.resource), + Request.load_opts(request, reuse_values?: true) + ), {:ok, result} <- Ash.load( result, - request.includes_keyword || [] + request.includes_keyword || [], + Request.load_opts(request) ) do Request.assign(request, :result, result) else @@ -302,11 +312,16 @@ defmodule AshJsonApi.Controllers.Helpers do with {:ok, result} <- Ash.run_action(action_input), {:ok, result} <- - Ash.load(result, fields(request, request.resource), reuse_values?: true), + Ash.load( + result, + fields(request, request.resource), + Request.load_opts(request, reuse_values?: true) + ), {:ok, result} <- Ash.load( result, - request.includes_keyword || [] + request.includes_keyword || [], + Request.load_opts(request) ) do Request.assign(request, :result, result) else @@ -418,7 +433,7 @@ defmodule AshJsonApi.Controllers.Helpers do |> case do {:ok, record} -> record - |> Ash.load(fields(request, request.resource), Request.opts(request)) + |> Ash.load(fields(request, request.resource), Request.load_opts(request)) |> case do {:ok, updated} -> request @@ -454,11 +469,16 @@ defmodule AshJsonApi.Controllers.Helpers do with {:ok, result} <- Ash.run_action(action_input), {:ok, result} <- - Ash.load(result, fields(request, request.resource), reuse_values?: true), + Ash.load( + result, + fields(request, request.resource), + Request.load_opts(request, reuse_values?: true) + ), {:ok, result} <- Ash.load( result, - request.includes_keyword || [] + request.includes_keyword || [], + Request.load_opts(request) ) do Request.assign(request, :result, result) else @@ -624,8 +644,10 @@ defmodule AshJsonApi.Controllers.Helpers do end with {:ok, result} <- Ash.run_action(action_input), - {:ok, result} <- Ash.load(result, load_lazy, reuse_values?: true), - {:ok, result} <- Ash.load(result, load) do + {:ok, result} <- + Ash.load(result, load_lazy, Request.load_opts(request, reuse_values?: true)), + {:ok, result} <- + Ash.load(result, load, Request.load_opts(request)) do request |> Request.assign(:result, result) |> Request.assign(:record_from_path, result) diff --git a/lib/ash_json_api/request.ex b/lib/ash_json_api/request.ex index 2a042e6..e619c0b 100644 --- a/lib/ash_json_api/request.ex +++ b/lib/ash_json_api/request.ex @@ -126,6 +126,13 @@ defmodule AshJsonApi.Request do ] end + def load_opts(request, merge) do + Keyword.merge( + load_opts(request), + merge + ) + end + def opts(request, merge \\ []) do page_params = Map.get(request.assigns, :page)