2017-03-21 09:21:52 +01:00
|
|
|
defmodule Pleroma.Activity do
|
|
|
|
use Ecto.Schema
|
2018-11-25 19:44:04 +01:00
|
|
|
alias Pleroma.{Repo, Activity, Notification, Object}
|
2018-11-29 07:52:54 +01:00
|
|
|
import Ecto.{Query, Changeset}
|
2017-03-21 09:21:52 +01:00
|
|
|
|
|
|
|
schema "activities" do
|
2018-03-30 15:01:53 +02: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 09:21:52 +01:00
|
|
|
|
|
|
|
timestamps()
|
|
|
|
end
|
2017-04-13 15:49:42 +02:00
|
|
|
|
|
|
|
def get_by_ap_id(ap_id) do
|
2018-03-30 15:01:53 +02:00
|
|
|
Repo.one(
|
|
|
|
from(
|
|
|
|
activity in Activity,
|
|
|
|
where: fragment("(?)->>'id' = ?", activity.data, ^to_string(ap_id))
|
|
|
|
)
|
|
|
|
)
|
2017-04-13 15:49:42 +02:00
|
|
|
end
|
|
|
|
|
2018-11-29 07:52:54 +01:00
|
|
|
def change(struct, params \\ %{}) do
|
|
|
|
struct
|
|
|
|
|> cast(params, [:data])
|
|
|
|
|> validate_required([:data])
|
|
|
|
|> unique_constraint(:ap_id, name: :activities_unique_apid_index)
|
|
|
|
end
|
|
|
|
|
2017-10-23 18:30:09 +02:00
|
|
|
# TODO:
|
|
|
|
# Go through these and fix them everywhere.
|
2017-08-16 16:29:25 +02:00
|
|
|
# Wrong name, only returns create activities
|
2017-08-01 17:05:07 +02:00
|
|
|
def all_by_object_ap_id_q(ap_id) do
|
2018-03-30 15:01:53 +02:00
|
|
|
from(
|
|
|
|
activity in Activity,
|
|
|
|
where:
|
|
|
|
fragment(
|
|
|
|
"coalesce((?)->'object'->>'id', (?)->>'object') = ?",
|
|
|
|
activity.data,
|
|
|
|
activity.data,
|
|
|
|
^to_string(ap_id)
|
|
|
|
),
|
2017-10-23 18:30:09 +02:00
|
|
|
where: fragment("(?)->>'type' = 'Create'", activity.data)
|
2018-03-30 15:01:53 +02:00
|
|
|
)
|
2017-08-01 17:05:07 +02:00
|
|
|
end
|
|
|
|
|
2017-10-23 18:30:09 +02:00
|
|
|
# Wrong name, returns all.
|
2017-08-16 16:29:25 +02:00
|
|
|
def all_non_create_by_object_ap_id_q(ap_id) do
|
2018-03-30 15:01:53 +02:00
|
|
|
from(
|
|
|
|
activity in Activity,
|
|
|
|
where:
|
|
|
|
fragment(
|
|
|
|
"coalesce((?)->'object'->>'id', (?)->>'object') = ?",
|
|
|
|
activity.data,
|
|
|
|
activity.data,
|
|
|
|
^to_string(ap_id)
|
|
|
|
)
|
|
|
|
)
|
2017-08-16 16:29:25 +02:00
|
|
|
end
|
|
|
|
|
2017-10-23 18:30:09 +02:00
|
|
|
# Wrong name plz fix thx
|
2017-04-13 15:49:42 +02:00
|
|
|
def all_by_object_ap_id(ap_id) do
|
2017-08-01 17:05:07 +02:00
|
|
|
Repo.all(all_by_object_ap_id_q(ap_id))
|
2017-04-13 15:49:42 +02:00
|
|
|
end
|
2017-04-30 11:16:41 +02:00
|
|
|
|
2018-03-27 18:18:24 +02:00
|
|
|
def create_activity_by_object_id_query(ap_ids) do
|
2018-03-30 15:01:53 +02:00
|
|
|
from(
|
|
|
|
activity in Activity,
|
|
|
|
where:
|
|
|
|
fragment(
|
|
|
|
"coalesce((?)->'object'->>'id', (?)->>'object') = ANY(?)",
|
|
|
|
activity.data,
|
|
|
|
activity.data,
|
|
|
|
^ap_ids
|
|
|
|
),
|
2018-03-27 18:18:24 +02:00
|
|
|
where: fragment("(?)->>'type' = 'Create'", activity.data)
|
2018-03-30 15:01:53 +02:00
|
|
|
)
|
2018-03-27 18:18:24 +02:00
|
|
|
end
|
|
|
|
|
2018-06-03 19:11:22 +02:00
|
|
|
def get_create_activity_by_object_ap_id(ap_id) when is_binary(ap_id) do
|
2018-03-27 18:18:24 +02:00
|
|
|
create_activity_by_object_id_query([ap_id])
|
2018-03-30 15:01:53 +02:00
|
|
|
|> Repo.one()
|
2017-04-30 11:16:41 +02:00
|
|
|
end
|
2018-06-03 19:11:22 +02:00
|
|
|
|
|
|
|
def get_create_activity_by_object_ap_id(_), do: nil
|
2018-06-18 22:54:59 +02:00
|
|
|
|
2018-11-25 22:34:36 +01:00
|
|
|
def normalize(obj) when is_map(obj), do: normalize(obj["id"])
|
|
|
|
def normalize(ap_id) when is_binary(ap_id), do: get_by_ap_id(ap_id)
|
2018-06-18 22:54:59 +02:00
|
|
|
def normalize(_), do: nil
|
2018-10-25 04:47:55 +02:00
|
|
|
|
2018-11-25 19:44:04 +01:00
|
|
|
defp get_in_reply_to_activity_from_object(%Object{data: %{"inReplyTo" => ap_id}}) do
|
2018-10-25 04:47:55 +02:00
|
|
|
get_create_activity_by_object_ap_id(ap_id)
|
|
|
|
end
|
|
|
|
|
2018-11-25 19:44:04 +01:00
|
|
|
defp get_in_reply_to_activity_from_object(_), do: nil
|
|
|
|
|
|
|
|
def get_in_reply_to_activity(%Activity{data: %{"object" => object}}) do
|
|
|
|
get_in_reply_to_activity_from_object(Object.normalize(object))
|
|
|
|
end
|
2017-03-21 09:21:52 +01:00
|
|
|
end
|