use Ecto.Schema
alias Pleroma.Activity
+ alias Pleroma.Bookmark
alias Pleroma.Notification
alias Pleroma.Object
alias Pleroma.Repo
import Ecto.Query
@type t :: %__MODULE__{}
+ @type actor :: String.t()
+
@primary_key {:id, Pleroma.FlakeId, autogenerate: true}
# https://github.com/tootsuite/mastodon/blob/master/app/models/notification.rb#L19
field(:actor, :string)
field(:recipients, {:array, :string}, default: [])
has_many(:notifications, Notification, on_delete: :delete_all)
+ has_many(:bookmarks, Bookmark, on_delete: :delete_all)
# Attention: this is a fake relation, don't try to preload it blindly and expect it to work!
# The foreign key is embedded in a jsonb field.
)
)
|> preload([activity, object], object: object)
+ |> with_preloaded_bookmarks()
+ end
+
+ def with_preloaded_bookmarks(query) do
+ query
+ |> preload(:bookmarks)
end
def get_by_ap_id(ap_id) do
),
preload: [object: o]
)
+ |> with_preloaded_bookmarks()
)
end
),
preload: [object: o]
)
+ |> with_preloaded_bookmarks()
|> Repo.one()
end
activity.data,
activity.data
),
- preload: [object: o]
+ preload: [object: o],
+ preload: :bookmarks
)
end
|> where([s], s.actor == ^actor)
|> Repo.all()
end
+
+ @spec query_by_actor(actor()) :: Ecto.Query.t()
+ def query_by_actor(actor) do
+ from(a in Activity, where: a.actor == ^actor)
+ end
end