mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-23 07:28:10 +00:00
Fix note counting.
This commit is contained in:
parent
47d883d3ab
commit
5c8f07f0a8
3 changed files with 23 additions and 18 deletions
|
@ -411,22 +411,19 @@ defmodule Pleroma.User do
|
||||||
end
|
end
|
||||||
|
|
||||||
def increase_note_count(%User{} = user) do
|
def increase_note_count(%User{} = user) do
|
||||||
note_count = (user.info["note_count"] || 0) + 1
|
info_cng = User.Info.add_to_note_count(user.info, 1)
|
||||||
new_info = Map.put(user.info, "note_count", note_count)
|
cng = change(user)
|
||||||
|
|> put_embed(:info, info_cng)
|
||||||
|
|
||||||
cs = info_changeset(user, %{info: new_info})
|
update_and_set_cache(cng)
|
||||||
|
|
||||||
update_and_set_cache(cs)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def decrease_note_count(%User{} = user) do
|
def decrease_note_count(%User{} = user) do
|
||||||
note_count = user.info["note_count"] || 0
|
info_cng = User.Info.add_to_note_count(user.info, -1)
|
||||||
note_count = if note_count <= 0, do: 0, else: note_count - 1
|
cng = change(user)
|
||||||
new_info = Map.put(user.info, "note_count", note_count)
|
|> put_embed(:info, info_cng)
|
||||||
|
|
||||||
cs = info_changeset(user, %{info: new_info})
|
update_and_set_cache(cng)
|
||||||
|
|
||||||
update_and_set_cache(cs)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def update_note_count(%User{} = user) do
|
def update_note_count(%User{} = user) do
|
||||||
|
|
|
@ -24,4 +24,12 @@ defmodule Pleroma.User.Info do
|
||||||
|> cast(params, [:deactivated])
|
|> cast(params, [:deactivated])
|
||||||
|> validate_required([:deactivated])
|
|> validate_required([:deactivated])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def add_to_note_count(info, number) do
|
||||||
|
params = %{note_count: Enum.max([0, info.note_count + number])}
|
||||||
|
|
||||||
|
info
|
||||||
|
|> cast(params, [:note_count])
|
||||||
|
|> validate_required([:note_count])
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -322,34 +322,34 @@ defmodule Pleroma.UserTest do
|
||||||
note = insert(:note)
|
note = insert(:note)
|
||||||
user = User.get_by_ap_id(note.data["actor"])
|
user = User.get_by_ap_id(note.data["actor"])
|
||||||
|
|
||||||
assert user.info["note_count"] == nil
|
assert user.info.note_count == 0
|
||||||
|
|
||||||
{:ok, user} = User.increase_note_count(user)
|
{:ok, user} = User.increase_note_count(user)
|
||||||
|
|
||||||
assert user.info["note_count"] == 1
|
assert user.info.note_count == 1
|
||||||
|
|
||||||
{:ok, user} = User.increase_note_count(user)
|
{:ok, user} = User.increase_note_count(user)
|
||||||
|
|
||||||
assert user.info["note_count"] == 2
|
assert user.info.note_count == 2
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it decreases the info->note_count property" do
|
test "it decreases the info->note_count property" do
|
||||||
note = insert(:note)
|
note = insert(:note)
|
||||||
user = User.get_by_ap_id(note.data["actor"])
|
user = User.get_by_ap_id(note.data["actor"])
|
||||||
|
|
||||||
assert user.info["note_count"] == nil
|
assert user.info.note_count == 0
|
||||||
|
|
||||||
{:ok, user} = User.increase_note_count(user)
|
{:ok, user} = User.increase_note_count(user)
|
||||||
|
|
||||||
assert user.info["note_count"] == 1
|
assert user.info.note_count == 1
|
||||||
|
|
||||||
{:ok, user} = User.decrease_note_count(user)
|
{:ok, user} = User.decrease_note_count(user)
|
||||||
|
|
||||||
assert user.info["note_count"] == 0
|
assert user.info.note_count == 0
|
||||||
|
|
||||||
{:ok, user} = User.decrease_note_count(user)
|
{:ok, user} = User.decrease_note_count(user)
|
||||||
|
|
||||||
assert user.info["note_count"] == 0
|
assert user.info.note_count == 0
|
||||||
end
|
end
|
||||||
|
|
||||||
test "it sets the info->follower_count property" do
|
test "it sets the info->follower_count property" do
|
||||||
|
|
Loading…
Reference in a new issue