Skip cache when /objects or /activities is authenticated

Ref: fix-local-public
This commit is contained in:
Tusooa Zhu 2022-05-05 19:20:32 -04:00 committed by FloatingGhost
parent 932e5df19e
commit 3fd87b6a75
1 changed files with 10 additions and 9 deletions

View File

@ -100,19 +100,20 @@ defmodule Pleroma.Web.Plugs.Cache do
should_cache = not Map.get(conn.assigns, :skip_cache, false)
conn =
cond do
Map.get(conn.assigns, :skip_cache, false) ->
conn
!opts[:tracking_fun] ->
unless opts[:tracking_fun] do
if should_cache do
@cachex.put(:web_resp_cache, key, {content_type, body}, ttl: ttl)
conn
end
true ->
tracking_fun_data = Map.get(conn.assigns, :tracking_fun_data, nil)
conn
else
tracking_fun_data = Map.get(conn.assigns, :tracking_fun_data, nil)
if should_cache do
@cachex.put(:web_resp_cache, key, {content_type, body, tracking_fun_data}, ttl: ttl)
end
opts.tracking_fun.(conn, tracking_fun_data)
opts.tracking_fun.(conn, tracking_fun_data)
end
put_resp_header(conn, "x-cache", "MISS from Pleroma")