refactor, status view updating, error handling
[akkoma] / lib / pleroma / user / info.ex
index ffb800177de59daf2127f004bc2f5a132248870d..9d8779fabb46be3ec8e4d05daa3f66ebd81d3632 100644 (file)
@@ -23,6 +23,7 @@ defmodule Pleroma.User.Info do
     field(:ap_enabled, :boolean, default: false)
     field(:is_moderator, :boolean, default: false)
     field(:is_admin, :boolean, default: false)
+    field(:show_role, :boolean, default: true)
     field(:keys, :string, default: nil)
     field(:settings, :map, default: nil)
     field(:magic_key, :string, default: nil)
@@ -30,8 +31,9 @@ defmodule Pleroma.User.Info do
     field(:topic, :string, default: nil)
     field(:hub, :string, default: nil)
     field(:salmon, :string, default: nil)
-    field(:hide_network, :boolean, default: false)
-    field(:pinned_activities, {:array, :integer}, default: [])
+    field(:hide_followers, :boolean, default: false)
+    field(:hide_follows, :boolean, default: false)
+    field(:pinned_activities, {:array, :string}, default: [])
 
     # Found in the wild
     # ap_id -> Where is this used?
@@ -42,8 +44,6 @@ defmodule Pleroma.User.Info do
     # subject _> Where is this used?
   end
 
-  def superuser?(info), do: info.is_admin || info.is_moderator
-
   def set_activation_status(info, deactivated) do
     params = %{deactivated: deactivated}
 
@@ -145,8 +145,10 @@ defmodule Pleroma.User.Info do
       :no_rich_text,
       :default_scope,
       :banner,
-      :hide_network,
-      :background
+      :hide_follows,
+      :hide_followers,
+      :background,
+      :show_role
     ])
   end
 
@@ -196,20 +198,21 @@ defmodule Pleroma.User.Info do
     info
     |> cast(params, [
       :is_moderator,
-      :is_admin
+      :is_admin,
+      :show_role
     ])
   end
 
   def add_pinnned_activity(info, %Pleroma.Activity{id: id}) do
     if id not in info.pinned_activities do
-      max_pinned_posts = Pleroma.Config.get([:instance, :max_pinned_posts], 0)
+      max_pinned_statuses = Pleroma.Config.get([:instance, :max_pinned_statuses], 0)
       params = %{pinned_activities: info.pinned_activities ++ [id]}
 
       info
       |> cast(params, [:pinned_activities])
       |> validate_length(:pinned_activities,
-        max: max_pinned_posts,
-        message: "You have already pinned the maximum number of toots"
+        max: max_pinned_statuses,
+        message: "You have already pinned the maximum number of statuses"
       )
     else
       change(info)