forked from AkkomaGang/akkoma
Move set_admin task to lib/mix/tasks/pleroma/user.ex
This commit is contained in:
parent
6f174cbb71
commit
ae82852330
2 changed files with 26 additions and 32 deletions
|
@ -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, [])
|
||||||
|
|
||||||
|
|
|
@ -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
|
|
Loading…
Reference in a new issue