First, add the dependency to your mix.exs
file
{:ash_archival, "~> 1.0.4"}
and add :ash_archival
to your .formatter.exs
import_deps: [..., :ash_archival]
To add archival to a resource, add the extension to the resource:
use Ash.Resource,
extensions: [..., AshArchival.Resource]
And thats it! Now, when you destroy a record, it will be archived instead, using an archived_at
attribute.
See How Does Ash Archival Work? for what modifications are made to a resource, and read on for info on the tradeoffs of leveraging d:Ash.Resource.Dsl.resource.base_filter
.
Using a d:Ash.Resource.Dsl.resource.base_filter
for your archived_at
field has a lot of benefits if you are using ash_postgres
, but comes with one major drawback, which is that it is not possible to exclude certain read actions from archival. If you wish to use a base filter, you will need to create a separate resource to read from the archived items. We may introduce a way to bypass the base filter at some point in the future.
To add a base_filter
and base_filter_sql
to your resource:
resource do
base_filter expr(is_nil(archived_at))
end
postgres do
...
base_filter_sql "(archived_at IS NULL)"
end
Add base_filter? true
to the archive
configuration of your resource to tell it that it doesn't need to add the filter itself.
- unique indexes will exclude archived items
- custom indexes will exclude archived items
- check constraints will not be applied to archived items
If you want these benefits, add the appropriate base_filter
.
See the Unarchiving guide For more.