forked from potsda.mn/mobilizon
e1e9b0fc11
Also add a unicity constraint on the followers table Signed-off-by: Thomas Citharel <tcit@tcit.fr>
25 lines
727 B
Elixir
25 lines
727 B
Elixir
defmodule Eventos.Actors.Follower do
|
|
@moduledoc """
|
|
Represents the following of an actor to another actor
|
|
"""
|
|
use Ecto.Schema
|
|
import Ecto.Changeset
|
|
alias Eventos.Actors.Follower
|
|
alias Eventos.Actors.Actor
|
|
|
|
schema "followers" do
|
|
field(:approved, :boolean, default: false)
|
|
field(:score, :integer, default: 1000)
|
|
belongs_to(:target_actor, Actor)
|
|
belongs_to(:actor, Actor)
|
|
end
|
|
|
|
@doc false
|
|
def changeset(%Follower{} = member, attrs) do
|
|
member
|
|
|> cast(attrs, [:score, :approved, :target_actor_id, :actor_id])
|
|
|> validate_required([:score, :approved, :target_actor_id, :actor_id])
|
|
|> unique_constraint(:target_actor_id, name: :followers_actor_target_actor_unique_index)
|
|
end
|
|
end
|