Don't spam logs about deleted users

User.get_or_fetch_by_(apid|nickname) are the only external users of fetch_and_prepare_user_from_ap_id,
thus there’s no point in duplicating logging, expecially not at error level.
Currently (duplicated) _not_found errors for users make up the bulk of my logs
and are created almost every second. Deleted users are a common occurence and not
worth logging outside of debug
This commit is contained in:
Oneric 2024-12-14 21:03:16 +01:00
parent 8d8132b46a
commit ad42de2ad7
5 changed files with 20 additions and 15 deletions

View file

@ -2003,8 +2003,16 @@ def get_or_fetch_by_ap_id(ap_id, options \\ []) do
Logger.debug("Rejected to fetch user due to MRF: #{ap_id}") Logger.debug("Rejected to fetch user due to MRF: #{ap_id}")
{:error, {:reject, :mrf}} {:error, {:reject, :mrf}}
e -> {_, {:error, :not_found}} ->
Logger.debug("User doesn't exist (anymore): #{ap_id}")
{:error, :not_found}
{_, {:error, e}} ->
Logger.error("Could not fetch user #{ap_id}, #{inspect(e)}") Logger.error("Could not fetch user #{ap_id}, #{inspect(e)}")
{:error, e}
e ->
Logger.error("Unexpected error condition while fetching user #{ap_id}, #{inspect(e)}")
{:error, :not_found} {:error, :not_found}
end end
end end

View file

@ -1750,19 +1750,16 @@ defp fetch_and_prepare_user_from_ap_id(ap_id, additional) do
else else
# If this has been deleted, only log a debug and not an error # If this has been deleted, only log a debug and not an error
{:error, {"Object has been deleted", _, _} = e} -> {:error, {"Object has been deleted", _, _} = e} ->
Logger.debug("Could not decode user at fetch #{ap_id}, #{inspect(e)}") Logger.debug("User was explicitly deleted #{ap_id}, #{inspect(e)}")
{:error, e} {:error, :not_found}
{:reject, reason} = e -> {:reject, _reason} = e ->
Logger.debug("Rejected user #{ap_id}: #{inspect(reason)}")
{:error, e} {:error, e}
{:valid, reason} -> {:valid, reason} ->
Logger.debug("Data is not a valid user #{ap_id}: #{inspect(reason)}") {:error, {:validate, reason}}
{:error, "Not a user"}
{:error, e} -> {:error, e} ->
Logger.error("Could not decode user at fetch #{ap_id}, #{inspect(e)}")
{:error, e} {:error, e}
end end
end end

View file

@ -241,11 +241,11 @@ test "it rejects posts without links" do
assert capture_log(fn -> assert capture_log(fn ->
{:reject, _} = AntiLinkSpamPolicy.filter(message) {:reject, _} = AntiLinkSpamPolicy.filter(message)
end) =~ "[error] Could not decode user at fetch http://invalid.actor" end) =~ "[error] Could not fetch user http://invalid.actor,"
assert capture_log(fn -> assert capture_log(fn ->
{:reject, _} = AntiLinkSpamPolicy.filter(update_message) {:reject, _} = AntiLinkSpamPolicy.filter(update_message)
end) =~ "[error] Could not decode user at fetch http://invalid.actor" end) =~ "[error] Could not fetch user http://invalid.actor,"
end end
test "it rejects posts with links" do test "it rejects posts with links" do
@ -259,11 +259,11 @@ test "it rejects posts with links" do
assert capture_log(fn -> assert capture_log(fn ->
{:reject, _} = AntiLinkSpamPolicy.filter(message) {:reject, _} = AntiLinkSpamPolicy.filter(message)
end) =~ "[error] Could not decode user at fetch http://invalid.actor" end) =~ "[error] Could not fetch user http://invalid.actor,"
assert capture_log(fn -> assert capture_log(fn ->
{:reject, _} = AntiLinkSpamPolicy.filter(update_message) {:reject, _} = AntiLinkSpamPolicy.filter(update_message)
end) =~ "[error] Could not decode user at fetch http://invalid.actor" end) =~ "[error] Could not fetch user http://invalid.actor,"
end end
end end

View file

@ -29,7 +29,7 @@ test "relay actor is invisible" do
test "returns errors when user not found" do test "returns errors when user not found" do
assert capture_log(fn -> assert capture_log(fn ->
{:error, _} = Relay.follow("test-ap-id") {:error, _} = Relay.follow("test-ap-id")
end) =~ "Could not decode user at fetch" end) =~ "Could not fetch user test-ap-id,"
end end
test "returns activity" do test "returns activity" do
@ -48,7 +48,7 @@ test "returns activity" do
test "returns errors when user not found" do test "returns errors when user not found" do
assert capture_log(fn -> assert capture_log(fn ->
{:error, _} = Relay.unfollow("test-ap-id") {:error, _} = Relay.unfollow("test-ap-id")
end) =~ "Could not decode user at fetch" end) =~ "Could not fetch user test-ap-id,"
end end
test "returns activity" do test "returns activity" do

View file

@ -132,7 +132,7 @@ test "show follow page with error when user can not be fetched by `acct` link",
|> html_response(200) |> html_response(200)
assert response =~ "Error fetching user" assert response =~ "Error fetching user"
end) =~ ":not_found" end) =~ "User doesn't exist (anymore): https://mastodon.social/users/not_found"
end end
end end