diff options
author | kaniini <nenolod@gmail.com> | 2018-11-22 00:28:04 +0000 |
---|---|---|
committer | kaniini <nenolod@gmail.com> | 2018-11-22 00:28:04 +0000 |
commit | 675653ceb78e4a64d8375904e555cdd62f064e21 (patch) | |
tree | 1f0cb4e0f4fa3a3f9a28cd9cf5a17da04cbfbc1c /lib/mix/tasks/set_admin.ex | |
parent | 182e3e8da2e5dbb8e8b7b514ad8bbdf242b37b59 (diff) | |
parent | 52681f7fd01c17876b03176cd82b299e6a342d56 (diff) | |
download | pleroma-675653ceb78e4a64d8375904e555cdd62f064e21.tar.gz |
Merge branch 'feature/admin-api' into 'develop'
Add a admin API
See merge request pleroma/pleroma!366
Diffstat (limited to 'lib/mix/tasks/set_admin.ex')
-rw-r--r-- | lib/mix/tasks/set_admin.ex | 32 |
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 |