X-Git-Url: http://git.squeep.com/?a=blobdiff_plain;f=lib%2Fpleroma%2Factivity.ex;h=9a5e6fc787c5035dcb5d5e5a7a1f5af058fbdfed;hb=73bdfd6c2b92533b5d48c2801a8e6548e8a2551a;hp=c4efc62839bc659cccd64591b3ba6770fe1978f5;hpb=8de523c8aec19e999334753b5a982fff00d1f44c;p=akkoma diff --git a/lib/pleroma/activity.ex b/lib/pleroma/activity.ex index c4efc6283..9a5e6fc78 100644 --- a/lib/pleroma/activity.ex +++ b/lib/pleroma/activity.ex @@ -1,9 +1,39 @@ defmodule Pleroma.Activity do use Ecto.Schema + alias Pleroma.{Repo, Activity, Notification} + import Ecto.Query schema "activities" do field :data, :map + field :local, :boolean, default: true + has_many :notifications, Notification 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 + + # Wrong name, only returns create activities + def all_by_object_ap_id_q(ap_id) do + from activity in Activity, + where: fragment("(?)->'object'->>'id' = ?", activity.data, ^to_string(ap_id)) + end + + def all_non_create_by_object_ap_id_q(ap_id) do + from activity in Activity, + where: fragment("(?)->>'object' = ?", activity.data, ^to_string(ap_id)) + end + + def all_by_object_ap_id(ap_id) do + Repo.all(all_by_object_ap_id_q(ap_id)) + end + + def get_create_activity_by_object_ap_id(ap_id) do + Repo.one(from activity in Activity, + where: fragment("(?)->'object'->>'id' = ?", activity.data, ^to_string(ap_id)) + and fragment("(?)->>'type' = 'Create'", activity.data)) + end end