View Source Ash.Resource.Change behaviour (ash v2.7.1)

The behaviour for an action-specific resource change.

init/1 is defined automatically by use Ash.Resource.Change, but can be implemented if you want to validate/transform any options passed to the module.

The main function is change/3. It takes the changeset, any options that were provided when this change was configured on a resource, and the context, which currently only has the actor.

Link to this section Summary

Link to this section Types

@type context() :: %{
  optional(:actor) => Ash.Resource.record(),
  optional(any()) => any()
}
@type ref() :: {module(), Keyword.t()} | module()
@type t() :: %Ash.Resource.Change{
  change: term(),
  description: term(),
  on: term(),
  only_when_valid?: term(),
  where: term()
}

Link to this section Callbacks

@callback change(Ash.Changeset.t(), Keyword.t(), context()) :: Ash.Changeset.t()
@callback init(Keyword.t()) :: {:ok, Keyword.t()} | {:error, term()}