Merge branch 'fix/mastodon-api-settings' into 'develop'
[akkoma] / lib / mix / tasks / make_moderator.ex
index a76b54f4069c973ad7ad2e53f80ef7b13933ff37..8dc0a04dd3213e3acc03ab2ac9b5d5ddb889fc8d 100644 (file)
@@ -1,27 +1,38 @@
 defmodule Mix.Tasks.SetModerator do
+  @moduledoc """
+  Set moderator to a local user
+
+  Usage: ``mix set_moderator <nickname>``
+
+  Example: ``mix set_moderator lain``
+  """
+
   use Mix.Task
-  import Mix.Ecto
+  import Ecto.Changeset
   alias Pleroma.{Repo, User}
 
-  @shortdoc "Set moderator status"
   def run([nickname | rest]) do
-    ensure_started(Repo, [])
+    Application.ensure_all_started(:pleroma)
 
-    moderator = case rest do
-                  [moderator] -> moderator == "true"
-                  _ -> true
-                end
+    moderator =
+      case rest do
+        [moderator] -> moderator == "true"
+        _ -> true
+      end
 
     with %User{local: true} = user <- User.get_by_nickname(nickname) do
-      info = user.info
-      |> Map.put("is_moderator", !!moderator)
-      cng = User.info_changeset(user, %{info: info})
-      user = Repo.update!(cng)
+      info_cng = User.Info.admin_api_update(user.info, %{is_moderator: !!moderator})
+
+      user_cng =
+        Ecto.Changeset.change(user)
+        |> put_embed(:info, info_cng)
+
+      {:ok, user} = User.update_and_set_cache(user_cng)
 
-      IO.puts "Moderator status of #{nickname}: #{user.info["is_moderator"]}"
+      IO.puts("Moderator status of #{nickname}: #{user.info.is_moderator}")
     else
       _ ->
-        IO.puts "No local user #{nickname}"
+        IO.puts("No local user #{nickname}")
     end
   end
 end