Move set_admin task to lib/mix/tasks/pleroma/user.ex

This commit is contained in:
rinpatch 2018-12-01 18:55:52 +03:00
parent 6f174cbb71
commit ae82852330
2 changed files with 26 additions and 32 deletions

View File

@ -15,6 +15,7 @@ defmodule Mix.Tasks.Pleroma.User do
- `--bio BIO` - the user's bio - `--bio BIO` - the user's bio
- `--password PASSWORD` - the user's password - `--password PASSWORD` - the user's password
- `--moderator`/`--no-moderator` - whether the user is a moderator - `--moderator`/`--no-moderator` - whether the user is a moderator
- `--admin`/`--no-admin` - whether the user is an admin
## Delete the user's account. ## Delete the user's account.
@ -35,6 +36,7 @@ defmodule Mix.Tasks.Pleroma.User do
Options: Options:
- `--locked`/`--no-locked` - whether the user's account is locked - `--locked`/`--no-locked` - whether the user's account is locked
- `--moderator`/`--no-moderator` - whether the user is a moderator - `--moderator`/`--no-moderator` - whether the user is a moderator
- `--admin`/`--no-admin` - whether the user is an admin
""" """
def run(["new", nickname, email | rest]) do def run(["new", nickname, email | rest]) do
@ -154,6 +156,7 @@ def run(["set", nickname | rest]) do
rest, rest,
strict: [ strict: [
moderator: :boolean, moderator: :boolean,
admin: :boolean,
locked: :boolean locked: :boolean
] ]
) )
@ -167,6 +170,11 @@ def run(["set", nickname | rest]) do
nil -> nil nil -> nil
value -> set_locked(nickname, value) value -> set_locked(nickname, value)
end end
case Keyword.get(options, :admin) do
nil -> nil
value -> set_admin(nickname, value)
end
end end
defp set_moderator(nickname, value) do defp set_moderator(nickname, value) do
@ -187,6 +195,24 @@ defp set_moderator(nickname, value) do
end end
end end
defp set_admin(nickname, value) do
Application.ensure_all_started(:pleroma)
with %User{local: true} = user <- User.get_by_nickname(nickname) do
info =
user.info
|> Map.put("is_admin", value)
cng = User.info_changeset(user, %{info: info})
{:ok, user} = User.update_and_set_cache(cng)
Mix.shell().info("Admin status of #{nickname}: #{user.info["is_admin"]}")
else
_ ->
Mix.shell().error("No local user #{nickname}")
end
end
defp set_locked(nickname, value) do defp set_locked(nickname, value) do
Mix.Ecto.ensure_started(Repo, []) Mix.Ecto.ensure_started(Repo, [])

View File

@ -1,32 +0,0 @@
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