pleroma/lib/pleroma/activity.ex

80 lines
1.8 KiB
Elixir
Raw Normal View History

2017-03-21 04:21:52 -04:00
defmodule Pleroma.Activity do
use Ecto.Schema
alias Pleroma.{Repo, Activity, Notification}
import Ecto.Query
2017-03-21 04:21:52 -04:00
schema "activities" do
2018-03-30 09:01:53 -04:00
field(:data, :map)
field(:local, :boolean, default: true)
field(:actor, :string)
field(:recipients, {:array, :string})
has_many(:notifications, Notification, on_delete: :delete_all)
2017-03-21 04:21:52 -04:00
timestamps()
end
def get_by_ap_id(ap_id) do
2018-03-30 09:01:53 -04:00
Repo.one(
from(
activity in Activity,
where: fragment("(?)->>'id' = ?", activity.data, ^to_string(ap_id))
)
)
end
2017-10-23 12:30:09 -04:00
# TODO:
# Go through these and fix them everywhere.
# Wrong name, only returns create activities
2017-08-01 11:05:07 -04:00
def all_by_object_ap_id_q(ap_id) do
2018-03-30 09:01:53 -04:00
from(
activity in Activity,
where:
fragment(
"coalesce((?)->'object'->>'id', (?)->>'object') = ?",
activity.data,
activity.data,
^to_string(ap_id)
),
2017-10-23 12:30:09 -04:00
where: fragment("(?)->>'type' = 'Create'", activity.data)
2018-03-30 09:01:53 -04:00
)
2017-08-01 11:05:07 -04:00
end
2017-10-23 12:30:09 -04:00
# Wrong name, returns all.
def all_non_create_by_object_ap_id_q(ap_id) do
2018-03-30 09:01:53 -04:00
from(
activity in Activity,
where:
fragment(
"coalesce((?)->'object'->>'id', (?)->>'object') = ?",
activity.data,
activity.data,
^to_string(ap_id)
)
)
end
2017-10-23 12:30:09 -04:00
# Wrong name plz fix thx
def all_by_object_ap_id(ap_id) do
2017-08-01 11:05:07 -04:00
Repo.all(all_by_object_ap_id_q(ap_id))
end
2018-03-27 12:18:24 -04:00
def create_activity_by_object_id_query(ap_ids) do
2018-03-30 09:01:53 -04:00
from(
activity in Activity,
where:
fragment(
"coalesce((?)->'object'->>'id', (?)->>'object') = ANY(?)",
activity.data,
activity.data,
^ap_ids
),
2018-03-27 12:18:24 -04:00
where: fragment("(?)->>'type' = 'Create'", activity.data)
2018-03-30 09:01:53 -04:00
)
2018-03-27 12:18:24 -04:00
end
def get_create_activity_by_object_ap_id(ap_id) do
2018-03-27 12:18:24 -04:00
create_activity_by_object_id_query([ap_id])
2018-03-30 09:01:53 -04:00
|> Repo.one()
end
2017-03-21 04:21:52 -04:00
end