X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Factivity.ex;h=c065f3b6ce690a688ead5a087135f46e44f13ba8;hb=c7d08bc1cf37417f8275839f493d09981f2f7e09;hp=c4efc62839bc659cccd64591b3ba6770fe1978f5;hpb=8de523c8aec19e999334753b5a982fff00d1f44c;p=akkoma diff --git a/lib/pleroma/activity.ex b/lib/pleroma/activity.ex index c4efc6283..c065f3b6c 100644 --- a/lib/pleroma/activity.ex +++ b/lib/pleroma/activity.ex @@ -1,9 +1,91 @@ defmodule Pleroma.Activity do use Ecto.Schema + alias Pleroma.{Repo, Activity, Notification} + import Ecto.Query schema "activities" do - field :data, :map + field(:data, :map) + field(:local, :boolean, default: true) + field(:actor, :string) + field(:recipients, {:array, :string}) + has_many(:notifications, Notification, on_delete: :delete_all) timestamps() end + + def get_by_ap_id(ap_id) do + Repo.one( + from( + activity in Activity, + where: fragment("(?)->>'id' = ?", activity.data, ^to_string(ap_id)) + ) + ) + end + + # TODO: + # Go through these and fix them everywhere. + # Wrong name, only returns create activities + def all_by_object_ap_id_q(ap_id) do + from( + activity in Activity, + where: + fragment( + "coalesce((?)->'object'->>'id', (?)->>'object') = ?", + activity.data, + activity.data, + ^to_string(ap_id) + ), + where: fragment("(?)->>'type' = 'Create'", activity.data) + ) + end + + # Wrong name, returns all. + def all_non_create_by_object_ap_id_q(ap_id) do + from( + activity in Activity, + where: + fragment( + "coalesce((?)->'object'->>'id', (?)->>'object') = ?", + activity.data, + activity.data, + ^to_string(ap_id) + ) + ) + end + + # Wrong name plz fix thx + def all_by_object_ap_id(ap_id) do + Repo.all(all_by_object_ap_id_q(ap_id)) + end + + def create_activity_by_object_id_query(ap_ids) do + from( + activity in Activity, + where: + fragment( + "coalesce((?)->'object'->>'id', (?)->>'object') = ANY(?)", + activity.data, + activity.data, + ^ap_ids + ), + where: fragment("(?)->>'type' = 'Create'", activity.data) + ) + end + + def get_create_activity_by_object_ap_id(ap_id) when is_binary(ap_id) do + create_activity_by_object_id_query([ap_id]) + |> Repo.one() + end + + def get_create_activity_by_object_ap_id(_), do: nil + + def normalize(obj) when is_map(obj), do: Activity.get_by_ap_id(obj["id"]) + def normalize(ap_id) when is_binary(ap_id), do: Activity.get_by_ap_id(ap_id) + def normalize(_), do: nil + + def get_in_reply_to_activity(%Activity{data: %{"object" => %{"inReplyTo" => ap_id}}}) do + get_create_activity_by_object_ap_id(ap_id) + end + + def get_in_reply_to_activity(_), do: nil end