Ash Resource for a TMF674 GeographicAddress.
Out-of-the-box concrete leaf derived from BasePlace + BaseGeographicAddress.
Sets type: :GeographicAddress on the :create action; accepts the union of
base Place + address-specific fields.
See Diffo.Provider.BaseGeographicAddress for the attribute set and TMF wire
shape. See Diffo.Provider.BasePlace for the base attributes, validations,
and Neo4j wiring inherited via fragment composition.
Cross-world consumers
Domain extenders compose the same two fragments on their own leaf rather than
extending this one — Ash resources are leaves, not hierarchies. See the
BaseGeographicAddress docstring for an example.
An Ash Resource for a TMF674 GeographicAddress
Summary
Types
@type t() :: %Diffo.Provider.GeographicAddress{ __lateral_join_source__: term(), __meta__: term(), __metadata__: term(), __order__: term(), aggregates: term(), bounds: term(), calculations: term(), country: term(), created_at: term(), href: term(), id: term(), locality: term(), location: term(), name: term(), place_refs: term(), postcode: term(), referred_type: term(), state_or_province: term(), street_name: term(), street_nr: term(), type: term(), updated_at: term() }
Functions
Validates that the keys in the provided input are valid for at least one action on the resource.
Raises a KeyError error at compile time if not. This exists because generally a struct should only ever
be created by Ash as a result of a successful action. You should not be creating records manually in code,
e.g %MyResource{value: 1, value: 2}. Generally that is fine, but often with embedded resources it is nice
to be able to validate the keys that are being provided, e.g
Resource
|> Ash.Changeset.for_create(:create, %{embedded: EmbeddedResource.input(foo: 1, bar: 2)})
|> Ash.create()
Same as input/1, except restricts the keys to values accepted by the action provided.