2017-03-21 09:21:52 +01:00
|
|
|
defmodule Pleroma.Activity do
|
|
|
|
use Ecto.Schema
|
2017-09-11 16:15:28 +02:00
|
|
|
alias Pleroma.{Repo, Activity, Notification}
|
2017-04-13 15:49:42 +02:00
|
|
|
import Ecto.Query
|
2017-03-21 09:21:52 +01:00
|
|
|
|
|
|
|
schema "activities" do
|
|
|
|
field :data, :map
|
2017-05-02 10:43:35 +02:00
|
|
|
field :local, :boolean, default: true
|
2017-09-11 16:15:28 +02:00
|
|
|
has_many :notifications, Notification
|
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
|
|
|
|
Repo.one(from activity in Activity,
|
2017-06-20 16:02:17 +02:00
|
|
|
where: fragment("(?)->>'id' = ?", activity.data, ^to_string(ap_id)))
|
2017-04-13 15:49:42 +02:00
|
|
|
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
|
|
|
|
from activity in Activity,
|
2017-10-23 18:30:09 +02:00
|
|
|
where: fragment("coalesce((?)->'object'->>'id', (?)->>'object') = ?", activity.data, activity.data, ^to_string(ap_id)),
|
|
|
|
where: fragment("(?)->>'type' = 'Create'", activity.data)
|
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
|
|
|
|
from activity in Activity,
|
2017-10-23 18:30:09 +02:00
|
|
|
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
|
|
|
|
|
|
|
def get_create_activity_by_object_ap_id(ap_id) do
|
|
|
|
Repo.one(from activity in Activity,
|
2017-10-23 18:36:53 +02:00
|
|
|
where: fragment("coalesce((?)->'object'->>'id', (?)->>'object') = ?", activity.data, activity.data, ^to_string(ap_id)),
|
|
|
|
where: fragment("(?)->>'type' = 'Create'", activity.data))
|
2017-04-30 11:16:41 +02:00
|
|
|
end
|
2017-03-21 09:21:52 +01:00
|
|
|
end
|