Reduce OP fetching queries.

This commit is contained in:
lain 2018-03-27 18:18:24 +02:00
commit 37e5014d3e
3 changed files with 46 additions and 11 deletions

View file

@ -38,9 +38,14 @@ defmodule Pleroma.Activity 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) do
Repo.one(from activity in Activity,
where: fragment("coalesce((?)->'object'->>'id', (?)->>'object') = ?", activity.data, activity.data, ^to_string(ap_id)),
where: fragment("(?)->>'type' = 'Create'", activity.data))
create_activity_by_object_id_query([ap_id])
|> Repo.one
end
end