Adds columns, fields, and queries for soft deletion with Ecto.
In migrations for schemas to support soft deletion, import Ecto.SoftDelete.Migration
. Next, add soft_delete_columns()
when creating a table
defmodule MyApp.Repo.Migrations.CreateUser do
use Ecto.Migration
import Ecto.SoftDelete.Migration
def change do
create table(:users) do
add :email, :string
add :password, :string
timestamps()
soft_delete_columns()
end
end
end
Import Ecto.SoftDelete.Schema
into your Schema module, then add soft_delete_schema()
to your schema
defmodule User do
use Ecto.Schema
import Ecto.SoftDelete.Schema
schema "users" do
field :email, :string
soft_delete_schema()
end
end
To query for items that have not been deleted, use with_undeleted(query)
which will filter out deleted items using the deleted_at
column produced by the previous 2 steps
import Ecto.SoftDelete.Query
query = from(u in User, select: u)
|> with_undeleted
results = Repo.all(query)
Add to mix.exs:
defp deps do
[{:ecto_soft_delete, "0.2.0"}]
end
and do
mix deps.get
There are currently no configuration options.
Bug reports and pull requests are welcome on GitHub at https://github.com/revelrylabs/ecto_soft_delete. Check out CONTRIBUTING.md for more info.
Everyone is welcome to participate in the project. We expect contributors to adhere the Contributor Covenant Code of Conduct (see CODE_OF_CONDUCT.md).