ash_postgres/test/support/resources/author.ex
Zach Daniel 37cc01957d
improvement!: 3.0 (#227)
* WIP

* chore: fix mix.lock merge issues

* improvement: upgrade to 3.0

* chore: remove `repo.to_tenant`

* chore: continue removal of unnecessary helper

* chore: use `Ash.ToTenant`
2024-03-27 16:52:28 -04:00

147 lines
3.7 KiB
Elixir

defmodule AshPostgres.Test.Author do
@moduledoc false
use Ash.Resource,
domain: AshPostgres.Test.Domain,
data_layer: AshPostgres.DataLayer
defmodule RuntimeFullName do
@moduledoc false
use Ash.Resource.Calculation
def calculate(records, _, _) do
Enum.map(records, fn record ->
record.first_name <> " " <> record.last_name
end)
end
end
postgres do
table("authors")
repo(AshPostgres.TestRepo)
end
attributes do
uuid_primary_key(:id, writable?: true)
attribute(:first_name, :string, public?: true)
attribute(:last_name, :string, public?: true)
attribute(:bio, AshPostgres.Test.Bio, public?: true)
attribute(:badges, {:array, :atom}, public?: true)
end
actions do
default_accept(:*)
defaults([:create, :read, :update, :destroy])
end
relationships do
has_one(:profile, AshPostgres.Test.Profile) do
public?(true)
end
has_many(:posts, AshPostgres.Test.Post) do
public?(true)
end
has_many :authors_with_same_first_name, __MODULE__ do
public?(true)
source_attribute(:first_name)
destination_attribute(:first_name)
filter(expr(parent(id) != id))
end
end
aggregates do
first(:profile_description, :profile, :description)
count(:count_of_posts, :posts)
end
calculations do
calculate(
:description,
:string,
expr(
if is_nil(^actor(:id)) do
"no actor"
else
profile_description
end
)
)
calculate(:count_of_posts_with_calc, :integer, expr(count(posts, [])))
calculate(:title, :string, expr(bio[:title]))
calculate(:full_name, :string, expr(first_name <> " " <> last_name))
calculate(:runtime_full_name, :string, RuntimeFullName)
calculate(
:expr_referencing_runtime,
:string,
expr(runtime_full_name <> " " <> runtime_full_name)
)
calculate(:full_name_with_nils, :string, expr(string_join([first_name, last_name], " ")))
calculate(:full_name_with_nils_no_joiner, :string, expr(string_join([first_name, last_name])))
calculate(:split_full_name, {:array, :string}, expr(string_split(full_name)))
calculate(
:split_full_name_trim,
{:array, :string},
expr(string_split(full_name, " ", trim?: true))
)
calculate(:first_name_from_split, :string, expr(at(split_full_name_trim, 0)))
calculate(:first_name_or_bob, :string, expr(first_name || "bob"))
calculate(:first_name_and_bob, :string, expr(first_name && "bob"))
calculate(
:conditional_full_name,
:string,
expr(
if(
is_nil(first_name) or is_nil(last_name),
"(none)",
first_name <> " " <> last_name
)
)
)
calculate(
:nested_conditional,
:string,
expr(
if(
is_nil(first_name),
"No First Name",
if(
is_nil(last_name),
"No Last Name",
first_name <> " " <> last_name
)
)
)
)
calculate :param_full_name,
:string,
{AshPostgres.Test.Concat, keys: [:first_name, :last_name]} do
argument(:separator, :string, default: " ", constraints: [allow_empty?: true, trim?: false])
end
calculate(:has_posts, :boolean, expr(exists(posts, true)))
end
aggregates do
count :count_of_posts_with_better_comment, [:posts, :comments] do
join_filter([:posts, :comments], expr(parent(score) < likes))
end
exists :has_post_with_better_comment, [:posts, :comments] do
join_filter([:posts, :comments], expr(parent(score) < likes))
end
count(:num_of_authors_with_same_first_name, :authors_with_same_first_name)
end
end