summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHaelwenn (lanodan) Monnier <contact@hacktivis.me>2018-10-12 05:12:09 +0200
committerHaelwenn (lanodan) Monnier <contact@hacktivis.me>2018-11-17 20:25:53 +0100
commit011a2e36b1bec75afab96b7ed529dd5c4f18af7a (patch)
tree005e2703b094b9edfb40d3ad24f8d4133a9a5539
parent7076d45cb6661731201a0224628b748a0f6782e8 (diff)
downloadpleroma-011a2e36b1bec75afab96b7ed529dd5c4f18af7a.tar.gz
pleroma-011a2e36b1bec75afab96b7ed529dd5c4f18af7a.zip
lib/mix/tasks/make_admin.ex: New task
-rw-r--r--lib/mix/tasks/set_admin.ex32
1 files changed, 32 insertions, 0 deletions
diff --git a/lib/mix/tasks/set_admin.ex b/lib/mix/tasks/set_admin.ex
new file mode 100644
index 000000000..d5ccf261b
--- /dev/null
+++ b/lib/mix/tasks/set_admin.ex
@@ -0,0 +1,32 @@
+defmodule Mix.Tasks.SetAdmin do
+ use Mix.Task
+ alias Pleroma.User
+
+ @doc """
+ Sets admin status
+ Usage: set_admin nickname [true|false]
+ """
+ def run([nickname | rest]) do
+ Application.ensure_all_started(:pleroma)
+
+ status =
+ case rest do
+ [status] -> status == "true"
+ _ -> true
+ end
+
+ with %User{local: true} = user <- User.get_by_nickname(nickname) do
+ info =
+ user.info
+ |> Map.put("is_admin", !!status)
+
+ cng = User.info_changeset(user, %{info: info})
+ {:ok, user} = User.update_and_set_cache(cng)
+
+ IO.puts("Admin status of #{nickname}: #{user.info["is_admin"]}")
+ else
+ _ ->
+ IO.puts("No local user #{nickname}")
+ end
+ end
+end