nulla/lib/nulla/models/note.ex
2025-06-17 12:06:36 +02:00

58 lines
1.5 KiB
Elixir

defmodule Nulla.Models.Note do
use Ecto.Schema
import Ecto.Changeset
import Ecto.Query
alias Nulla.Repo
alias Nulla.Models.Actor
alias Nulla.Models.MediaAttachment
@primary_key {:id, :integer, autogenerate: false}
schema "notes" do
field :content, :string
field :visibility, Ecto.Enum,
values: [:public, :unlisted, :followers, :private],
default: :public
field :sensitive, :boolean, default: false
field :language, :string
field :in_reply_to, :string
belongs_to :actor, Actor
has_many :media_attachments, MediaAttachment
timestamps(type: :utc_datetime)
end
@doc false
def changeset(note, attrs) do
note
|> cast(attrs, [:content, :visibility, :sensitive, :language, :in_reply_to, :actor_id])
|> validate_required([:content, :visibility, :sensitive, :language, :in_reply_to, :actor_id])
end
def get_note!(id), do: Repo.get!(__MODULE__, id)
def get_latest_notes(actor_id, limit \\ 20) do
from(n in __MODULE__,
where: n.actor_id == ^actor_id,
order_by: [desc: n.inserted_at],
limit: ^limit
)
|> Repo.all()
end
def get_before_notes(actor_id, max_id, limit \\ 20) do
from(n in __MODULE__,
where: n.actor_id == ^actor_id and n.id < ^max_id,
order_by: [desc: n.inserted_at],
limit: ^limit
)
|> Repo.all()
end
def get_total_notes_count(actor_id) do
from(n in __MODULE__, where: n.actor_id == ^actor_id)
|> Repo.aggregate(:count, :id)
end
end