aboutsummaryrefslogtreecommitdiff
path: root/lib/pleroma/web/preload
diff options
context:
space:
mode:
Diffstat (limited to 'lib/pleroma/web/preload')
-rw-r--r--lib/pleroma/web/preload/timelines.ex31
1 files changed, 14 insertions, 17 deletions
diff --git a/lib/pleroma/web/preload/timelines.ex b/lib/pleroma/web/preload/timelines.ex
index dbd7db407..2bb57567b 100644
--- a/lib/pleroma/web/preload/timelines.ex
+++ b/lib/pleroma/web/preload/timelines.ex
@@ -11,32 +11,29 @@ defmodule Pleroma.Web.Preload.Providers.Timelines do
@public_url :"/api/v1/timelines/public"
@impl Provider
- def generate_terms(_params) do
- build_public_tag(%{})
+ def generate_terms(params) do
+ build_public_tag(%{}, params)
end
- def build_public_tag(acc) do
+ def build_public_tag(acc, params) do
if Pleroma.Config.get([:restrict_unauthenticated, :timelines, :federated], true) do
acc
else
- Map.put(acc, @public_url, public_timeline(nil))
+ Map.put(acc, @public_url, public_timeline(params))
end
end
- defp public_timeline(user) do
- activities =
- create_timeline_params(user)
- |> Map.put("local_only", false)
- |> ActivityPub.fetch_public_activities()
+ defp public_timeline(%{"path" => ["main", "all"]}), do: get_public_timeline(false)
- StatusView.render("index.json", activities: activities, for: user, as: :activity)
- end
+ defp public_timeline(_params), do: get_public_timeline(true)
+
+ defp get_public_timeline(local_only) do
+ activities =
+ ActivityPub.fetch_public_activities(%{
+ "type" => ["Create"],
+ "local_only" => local_only
+ })
- defp create_timeline_params(user) do
- %{}
- |> Map.put("type", ["Create", "Announce"])
- |> Map.put("blocking_user", user)
- |> Map.put("muting_user", user)
- |> Map.put("user", user)
+ StatusView.render("index.json", activities: activities, for: nil, as: :activity)
end
end