mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-24 16:08:09 +00:00
[#1505] Background fetching of incoming activities' replies
collections.
This commit is contained in:
parent
cf96c40057
commit
86e4d23acb
5 changed files with 87 additions and 1 deletions
|
@ -501,6 +501,7 @@ config :pleroma, Oban,
|
||||||
transmogrifier: 20,
|
transmogrifier: 20,
|
||||||
scheduled_activities: 10,
|
scheduled_activities: 10,
|
||||||
background: 5,
|
background: 5,
|
||||||
|
remote_fetcher: 2,
|
||||||
attachments_cleanup: 5
|
attachments_cleanup: 5
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
@ -424,7 +424,13 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do
|
||||||
])
|
])
|
||||||
}
|
}
|
||||||
|
|
||||||
ActivityPub.create(params)
|
with {:ok, created_activity} <- ActivityPub.create(params) do
|
||||||
|
for reply_id <- replies(object) do
|
||||||
|
Pleroma.Workers.RemoteFetcherWorker.enqueue("fetch_remote", %{"id" => reply_id})
|
||||||
|
end
|
||||||
|
|
||||||
|
{:ok, created_activity}
|
||||||
|
end
|
||||||
else
|
else
|
||||||
%Activity{} = activity -> {:ok, activity}
|
%Activity{} = activity -> {:ok, activity}
|
||||||
_e -> :error
|
_e -> :error
|
||||||
|
@ -946,6 +952,13 @@ defmodule Pleroma.Web.ActivityPub.Transmogrifier do
|
||||||
Map.merge(obj, %{"replies" => replies_collection})
|
Map.merge(obj, %{"replies" => replies_collection})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def replies(%{"replies" => replies = %{}}) do
|
||||||
|
replies = with %{} <- replies["first"], do: replies["first"], else: (_ -> replies)
|
||||||
|
replies["items"] || []
|
||||||
|
end
|
||||||
|
|
||||||
|
def replies(_), do: []
|
||||||
|
|
||||||
# Prepares the object of an outgoing create activity.
|
# Prepares the object of an outgoing create activity.
|
||||||
def prepare_object(object) do
|
def prepare_object(object) do
|
||||||
object
|
object
|
||||||
|
|
20
lib/pleroma/workers/remote_fetcher_worker.ex
Normal file
20
lib/pleroma/workers/remote_fetcher_worker.ex
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
defmodule Pleroma.Workers.RemoteFetcherWorker do
|
||||||
|
alias Pleroma.Object.Fetcher
|
||||||
|
|
||||||
|
use Pleroma.Workers.WorkerHelper, queue: "remote_fetcher"
|
||||||
|
|
||||||
|
@impl Oban.Worker
|
||||||
|
def perform(
|
||||||
|
%{
|
||||||
|
"op" => "fetch_remote",
|
||||||
|
"id" => id
|
||||||
|
},
|
||||||
|
_job
|
||||||
|
) do
|
||||||
|
Fetcher.fetch_object_from_id!(id)
|
||||||
|
end
|
||||||
|
end
|
|
@ -9,6 +9,10 @@ defmodule Pleroma.Tests.ObanHelpers do
|
||||||
|
|
||||||
alias Pleroma.Repo
|
alias Pleroma.Repo
|
||||||
|
|
||||||
|
def wipe_all do
|
||||||
|
Repo.delete_all(Oban.Job)
|
||||||
|
end
|
||||||
|
|
||||||
def perform_all do
|
def perform_all do
|
||||||
Oban.Job
|
Oban.Job
|
||||||
|> Repo.all()
|
|> Repo.all()
|
||||||
|
|
|
@ -3,7 +3,9 @@
|
||||||
# SPDX-License-Identifier: AGPL-3.0-only
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do
|
defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do
|
||||||
|
use Oban.Testing, repo: Pleroma.Repo
|
||||||
use Pleroma.DataCase
|
use Pleroma.DataCase
|
||||||
|
|
||||||
alias Pleroma.Activity
|
alias Pleroma.Activity
|
||||||
alias Pleroma.Object
|
alias Pleroma.Object
|
||||||
alias Pleroma.Object.Fetcher
|
alias Pleroma.Object.Fetcher
|
||||||
|
@ -1329,6 +1331,52 @@ defmodule Pleroma.Web.ActivityPub.TransmogrifierTest do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "handle_incoming:`replies` handling" do
|
||||||
|
setup do
|
||||||
|
data =
|
||||||
|
File.read!("test/fixtures/mastodon-post-activity.json")
|
||||||
|
|> Poison.decode!()
|
||||||
|
|
||||||
|
items = ["https://shitposter.club/notice/2827873", "https://shitposter.club/notice/7387606"]
|
||||||
|
collection = %{"items" => items}
|
||||||
|
%{data: data, items: items, collection: collection}
|
||||||
|
end
|
||||||
|
|
||||||
|
test "it schedules background fetching of wrapped `replies` collection items", %{
|
||||||
|
data: data,
|
||||||
|
items: items,
|
||||||
|
collection: collection
|
||||||
|
} do
|
||||||
|
replies = %{"first" => collection}
|
||||||
|
|
||||||
|
object = Map.put(data["object"], "replies", replies)
|
||||||
|
data = Map.put(data, "object", object)
|
||||||
|
{:ok, _activity} = Transmogrifier.handle_incoming(data)
|
||||||
|
|
||||||
|
for id <- items do
|
||||||
|
job_args = %{"op" => "fetch_remote", "id" => id}
|
||||||
|
assert_enqueued(worker: Pleroma.Workers.RemoteFetcherWorker, args: job_args)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
test "it schedules background fetching of unwrapped `replies` collection items", %{
|
||||||
|
data: data,
|
||||||
|
items: items,
|
||||||
|
collection: collection
|
||||||
|
} do
|
||||||
|
replies = collection
|
||||||
|
|
||||||
|
object = Map.put(data["object"], "replies", replies)
|
||||||
|
data = Map.put(data, "object", object)
|
||||||
|
{:ok, _activity} = Transmogrifier.handle_incoming(data)
|
||||||
|
|
||||||
|
for id <- items do
|
||||||
|
job_args = %{"op" => "fetch_remote", "id" => id}
|
||||||
|
assert_enqueued(worker: Pleroma.Workers.RemoteFetcherWorker, args: job_args)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
describe "prepare outgoing" do
|
describe "prepare outgoing" do
|
||||||
test "it inlines private announced objects" do
|
test "it inlines private announced objects" do
|
||||||
user = insert(:user)
|
user = insert(:user)
|
||||||
|
|
Loading…
Reference in a new issue