1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
5 defmodule Pleroma.User.Info do
10 field(:banner, :map, default: %{})
11 field(:background, :map, default: %{})
12 field(:source_data, :map, default: %{})
13 field(:note_count, :integer, default: 0)
14 field(:follower_count, :integer, default: 0)
15 field(:locked, :boolean, default: false)
16 field(:confirmation_pending, :boolean, default: false)
17 field(:confirmation_token, :string, default: nil)
18 field(:default_scope, :string, default: "public")
19 field(:blocks, {:array, :string}, default: [])
20 field(:domain_blocks, {:array, :string}, default: [])
21 field(:deactivated, :boolean, default: false)
22 field(:no_rich_text, :boolean, default: false)
23 field(:ap_enabled, :boolean, default: false)
24 field(:is_moderator, :boolean, default: false)
25 field(:is_admin, :boolean, default: false)
26 field(:keys, :string, default: nil)
27 field(:settings, :map, default: nil)
28 field(:magic_key, :string, default: nil)
29 field(:uri, :string, default: nil)
30 field(:topic, :string, default: nil)
31 field(:hub, :string, default: nil)
32 field(:salmon, :string, default: nil)
33 field(:hide_followers, :boolean, default: false)
34 field(:hide_followings, :boolean, default: false)
35 field(:pinned_activities, {:array, :string}, default: [])
38 # ap_id -> Where is this used?
39 # bio -> Where is this used?
40 # avatar -> Where is this used?
41 # fqn -> Where is this used?
42 # host -> Where is this used?
43 # subject _> Where is this used?
46 def set_activation_status(info, deactivated) do
47 params = %{deactivated: deactivated}
50 |> cast(params, [:deactivated])
51 |> validate_required([:deactivated])
54 def add_to_note_count(info, number) do
55 set_note_count(info, info.note_count + number)
58 def set_note_count(info, number) do
59 params = %{note_count: Enum.max([0, number])}
62 |> cast(params, [:note_count])
63 |> validate_required([:note_count])
66 def set_follower_count(info, number) do
67 params = %{follower_count: Enum.max([0, number])}
70 |> cast(params, [:follower_count])
71 |> validate_required([:follower_count])
74 def set_blocks(info, blocks) do
75 params = %{blocks: blocks}
78 |> cast(params, [:blocks])
79 |> validate_required([:blocks])
82 def add_to_block(info, blocked) do
83 set_blocks(info, Enum.uniq([blocked | info.blocks]))
86 def remove_from_block(info, blocked) do
87 set_blocks(info, List.delete(info.blocks, blocked))
90 def set_domain_blocks(info, domain_blocks) do
91 params = %{domain_blocks: domain_blocks}
94 |> cast(params, [:domain_blocks])
95 |> validate_required([:domain_blocks])
98 def add_to_domain_block(info, domain_blocked) do
99 set_domain_blocks(info, Enum.uniq([domain_blocked | info.domain_blocks]))
102 def remove_from_domain_block(info, domain_blocked) do
103 set_domain_blocks(info, List.delete(info.domain_blocks, domain_blocked))
106 def set_keys(info, keys) do
107 params = %{keys: keys}
110 |> cast(params, [:keys])
111 |> validate_required([:keys])
114 def remote_user_creation(info, params) do
129 def user_upgrade(info, params) do
140 def profile_update(info, params) do
153 def confirmation_changeset(info, :confirmed) do
154 confirmation_changeset(info, %{
155 confirmation_pending: false,
156 confirmation_token: nil
160 def confirmation_changeset(info, :unconfirmed) do
161 confirmation_changeset(info, %{
162 confirmation_pending: true,
163 confirmation_token: :crypto.strong_rand_bytes(32) |> Base.url_encode64()
167 def confirmation_changeset(info, params) do
168 cast(info, params, [:confirmation_pending, :confirmation_token])
171 def mastodon_profile_update(info, params) do
179 def mastodon_settings_update(info, settings) do
180 params = %{settings: settings}
183 |> cast(params, [:settings])
184 |> validate_required([:settings])
187 def set_source_data(info, source_data) do
188 params = %{source_data: source_data}
191 |> cast(params, [:source_data])
192 |> validate_required([:source_data])
195 def admin_api_update(info, params) do
203 def add_pinnned_activity(info, %Pleroma.Activity{id: id}) do
204 if id not in info.pinned_activities do
205 max_pinned_statuses = Pleroma.Config.get([:instance, :max_pinned_statuses], 0)
206 params = %{pinned_activities: info.pinned_activities ++ [id]}
209 |> cast(params, [:pinned_activities])
210 |> validate_length(:pinned_activities,
211 max: max_pinned_statuses,
212 message: "You have already pinned the maximum number of statuses"
219 def remove_pinnned_activity(info, %Pleroma.Activity{id: id}) do
220 params = %{pinned_activities: List.delete(info.pinned_activities, id)}
222 cast(info, params, [:pinned_activities])