forked from AkkomaGang/akkoma
Update user reference after fetch
Since we always followed redirects (and until recently allowed fuzzy id matches), the ap_id of the received object might differ from the iniital fetch url. This lead to us mistakenly trying to insert a new user with the same nickname, ap_id, etc as an existing user (which will fail due to uniqueness constraints) instead of updating the existing one.
This commit is contained in:
parent
9061d148be
commit
48b3a35793
1 changed files with 7 additions and 0 deletions
|
@ -1840,6 +1840,13 @@ def make_user_from_ap_id(ap_id, additional \\ []) do
|
||||||
with {:ok, data} <- fetch_and_prepare_user_from_ap_id(ap_id, additional) do
|
with {:ok, data} <- fetch_and_prepare_user_from_ap_id(ap_id, additional) do
|
||||||
{:ok, _pid} = Task.start(fn -> pinned_fetch_task(data) end)
|
{:ok, _pid} = Task.start(fn -> pinned_fetch_task(data) end)
|
||||||
|
|
||||||
|
user =
|
||||||
|
if data.ap_id != ap_id do
|
||||||
|
User.get_cached_by_ap_id(data.ap_id)
|
||||||
|
else
|
||||||
|
user
|
||||||
|
end
|
||||||
|
|
||||||
if user do
|
if user do
|
||||||
user
|
user
|
||||||
|> User.remote_user_changeset(data)
|
|> User.remote_user_changeset(data)
|
||||||
|
|
Loading…
Reference in a new issue