aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2018-03-27 18:18:24 +0200
committerlain <lain@soykaf.club>2018-03-27 18:18:24 +0200
commit37e5014d3ee571622d324cdadfc2bf7c345cc1fc (patch)
tree833c5a5caed5b2f30b527aca309d34f90909a20c /lib
parentff7afe46b9b08fc59ea1451add167f0856d15dbf (diff)
downloadpleroma-37e5014d3ee571622d324cdadfc2bf7c345cc1fc.tar.gz
Reduce OP fetching queries.
Diffstat (limited to 'lib')
-rw-r--r--lib/pleroma/activity.ex11
-rw-r--r--lib/pleroma/web/mastodon_api/views/status_view.ex38
2 files changed, 39 insertions, 10 deletions
diff --git a/lib/pleroma/activity.ex b/lib/pleroma/activity.ex
index a8154859a..96ddcc480 100644
--- a/lib/pleroma/activity.ex
+++ b/lib/pleroma/activity.ex
@@ -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
diff --git a/lib/pleroma/web/mastodon_api/views/status_view.ex b/lib/pleroma/web/mastodon_api/views/status_view.ex
index 822a6800c..a4539d47e 100644
--- a/lib/pleroma/web/mastodon_api/views/status_view.ex
+++ b/lib/pleroma/web/mastodon_api/views/status_view.ex
@@ -4,9 +4,25 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do
alias Pleroma.{User, Activity}
alias Pleroma.Web.CommonAPI.Utils
alias Pleroma.Web.MediaProxy
+ alias Pleroma.Repo
+
+ # TODO: Add cached version.
+ defp get_replied_to_activities(activities) do
+ activities
+ |> Enum.map(fn
+ (%{data: %{"type" => "Create", "object" => %{"inReplyTo" => inReplyTo}}}) ->
+ (inReplyTo != "") && inReplyTo
+ _ -> nil
+ end)
+ |> Enum.filter(&(&1))
+ |> Activity.create_activity_by_object_id_query()
+ |> Repo.all
+ |> Enum.reduce(%{}, fn(activity, acc) -> Map.put(acc,activity.data["object"]["id"], activity) end)
+ end
def render("index.json", opts) do
- render_many(opts.activities, StatusView, "status.json", opts)
+ replied_to_activities = get_replied_to_activities(opts.activities)
+ render_many(opts.activities, StatusView, "status.json", Map.put(opts, :replied_to_activities, replied_to_activities))
end
def render("status.json", %{activity: %{data: %{"type" => "Announce", "object" => object}} = activity} = opts) do
@@ -51,6 +67,19 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do
}
end
+ def get_reply_to(activity, %{replied_to_activities: replied_to_activities}) do
+ id = activity.data["object"]["inReplyTo"]
+ replied_to_activities[activity.data["object"]["inReplyTo"]]
+ end
+
+ def get_reply_to(%{data: %{"object" => object}}, _) do
+ if object["inReplyTo"] && object["inReplyTo"] != "" do
+ Activity.get_create_activity_by_object_ap_id(object["inReplyTo"])
+ else
+ nil
+ end
+ end
+
def render("status.json", %{activity: %{data: %{"object" => object}} = activity} = opts) do
user = User.get_cached_by_ap_id(activity.data["actor"])
@@ -72,12 +101,7 @@ defmodule Pleroma.Web.MastodonAPI.StatusView do
created_at = Utils.to_masto_date(object["published"])
- # TODO: Add cached version.
- reply_to = if object["inReplyTo"] && object["inReplyTo"] != "" do
- Activity.get_create_activity_by_object_ap_id(object["inReplyTo"])
- else
- nil
- end
+ reply_to = get_reply_to(activity, opts)
reply_to_user = reply_to && User.get_cached_by_ap_id(reply_to.data["actor"])
emojis = (activity.data["object"]["emoji"] || [])