diff options
| author | Haelwenn (lanodan) Monnier <contact@hacktivis.me> | 2018-10-12 05:12:09 +0200 | 
|---|---|---|
| committer | Haelwenn (lanodan) Monnier <contact@hacktivis.me> | 2018-11-17 20:25:53 +0100 | 
| commit | 011a2e36b1bec75afab96b7ed529dd5c4f18af7a (patch) | |
| tree | 005e2703b094b9edfb40d3ad24f8d4133a9a5539 /lib | |
| parent | 7076d45cb6661731201a0224628b748a0f6782e8 (diff) | |
| download | pleroma-011a2e36b1bec75afab96b7ed529dd5c4f18af7a.tar.gz pleroma-011a2e36b1bec75afab96b7ed529dd5c4f18af7a.zip  | |
lib/mix/tasks/make_admin.ex: New task
Diffstat (limited to 'lib')
| -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  | 
