Preload bookmarks wherever the object is preloaded

This commit is contained in:
rinpatch 2019-05-04 12:46:42 +03:00 committed by William Pitcock
commit f841eb7cdb
3 changed files with 45 additions and 3 deletions

View file

@ -6,6 +6,7 @@ defmodule Pleroma.Activity do
use Ecto.Schema
alias Pleroma.Activity
alias Pleroma.Bookmark
alias Pleroma.Notification
alias Pleroma.Object
alias Pleroma.Repo
@ -36,6 +37,7 @@ defmodule Pleroma.Activity do
field(:actor, :string)
field(:recipients, {:array, :string}, default: [])
has_many(:notifications, Notification, on_delete: :delete_all)
has_many(:bookmarks, Bookmark, on_delete: :delete_all)
# Attention: this is a fake relation, don't try to preload it blindly and expect it to work!
# The foreign key is embedded in a jsonb field.
@ -71,6 +73,7 @@ defmodule Pleroma.Activity do
)
)
|> preload([activity, object], object: object)
|> preload(:bookmarks)
end
def get_by_ap_id(ap_id) do
@ -102,7 +105,8 @@ defmodule Pleroma.Activity do
activity.data,
activity.data
),
preload: [object: o]
preload: [object: o],
preload: :bookmarks
)
)
end
@ -122,7 +126,8 @@ defmodule Pleroma.Activity do
activity.data,
activity.data
),
preload: [object: o]
preload: [object: o],
preload: :bookmarks
)
|> Repo.one()
end
@ -200,7 +205,8 @@ defmodule Pleroma.Activity do
activity.data,
activity.data
),
preload: [object: o]
preload: [object: o],
preload: :bookmarks
)
end

View file

@ -137,6 +137,13 @@ defmodule Pleroma.Web.ActivityPub.ActivityPub do
activity
end
activity =
if activity.data["type"] in ["Create", "Announce"] do
Repo.preload(activity, :bookmarks)
else
activity
end
Task.start(fn ->
Pleroma.Web.RichMedia.Helpers.fetch_data_for_activity(activity)
end)