Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions lib/geo/geography/country.ex
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@ defmodule Geo.Geography.Country do
use Ash.Resource,
otp_app: :geo,
domain: Geo.Geography,
data_layer: AshPostgres.DataLayer
data_layer: AshPostgres.DataLayer,
extensions: [Geo.Resources.Extensions.Id]

# === Attributes ===
use Geo.Resources.Attributes.Id
use Geo.Resources.Attributes.Name, allow_nil?: false, unique?: true
use Geo.Resources.Attributes.Slug, allow_nil?: false, unique?: true
use Geo.Resources.Attributes.Timestamps
Expand Down
2 changes: 1 addition & 1 deletion lib/geo/resources/attributes/id.ex
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
defmodule Geo.Resources.Attributes.Id do
defmodule Geo.Resources.Attributes.Id.Defunct do
@moduledoc """
"""

Expand Down
33 changes: 33 additions & 0 deletions lib/geo/resources/extensions/id.ex
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
defmodule Geo.Resources.Extensions.Id do
@moduledoc """
An Ash extension that adds a UUID v7 primary key attribute to a resource.
"""

use Spark.Dsl.Extension,
transformers: [
__MODULE__.Transformer
]

defmodule Transformer do
@moduledoc false
use Spark.Dsl.Transformer

def before?(Ash.Resource.Transformers.BelongsToAttribute), do: true
def before?(_), do: false

def transform(dsl_state) do
case Spark.Dsl.Transformer.build_entity(
Ash.Resource.Dsl,
[:attributes],
:uuid_v7_primary_key,
[:id]
) do
{:ok, attribute} ->
{:ok, Spark.Dsl.Transformer.add_entity(dsl_state, [:attributes], attribute)}

{:error, error} ->
{:error, error}
end
end
end
end
Loading