Backpex.Adapter behaviour (Backpex v0.16.1)
View SourceSpecification of the datalayer adapter.
Work in progress
The Backpex.Adapter
behaviour is currently under heavy development and will change drastically in future updates.
Backpex started out as Ecto
-only and this is still deeply embedded in the core. We are working on changing this.
Do not rely on the current API to build new adapters, as the callbacks will still change significantly. This will be
an iterative process over the next few releases.
Summary
Callbacks
Applies a change to a given item.
Gets the total count of the current live_resource. Possibly being constrained the item query and the search- and filter options.
Deletes multiple items.
Gets a database record with the given primary key value.
Inserts given item.
Returns a list of items by given criteria.
Updates given item.
Updates given items.
Callbacks
@callback change( item :: struct(), attrs :: map(), fields :: term(), assigns :: list(), live_resource :: module(), opts :: keyword() ) :: Ecto.Changeset.t()
Applies a change to a given item.
@callback count( criteria :: keyword(), fields :: list(), assigns :: map(), live_resource :: module() ) :: {:ok, non_neg_integer()}
Gets the total count of the current live_resource. Possibly being constrained the item query and the search- and filter options.
@callback delete_all(items :: [struct()], live_resource :: module()) :: {:ok, term()} | {:error, term()}
Deletes multiple items.
@callback get( primary_value :: term(), fields :: list(), assigns :: map(), live_resource :: module() ) :: {:ok, struct() | nil} | {:error, term()}
Gets a database record with the given primary key value.
Should return nil
if no result was found.
Inserts given item.
@callback list( criteria :: keyword(), fields :: list(), assigns :: map(), live_resource :: module() ) :: {:ok, list()}
Returns a list of items by given criteria.
Updates given item.
@callback update_all(items :: [struct()], updates :: keyword(), live_resource :: module()) :: {:ok, non_neg_integer()}
Updates given items.