aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorRin Toshaka <rinpatch@sdf.org>2018-12-02 09:36:31 +0100
committerRin Toshaka <rinpatch@sdf.org>2018-12-02 09:36:31 +0100
commita8ef6b1190aff949140e0c79603d833668647a31 (patch)
treef3ca8a4552ca58ccf9be37d3d2fa5f91b30c2a39 /lib
parentae82852330105edb681d131fd33cf35557c8614c (diff)
downloadpleroma-a8ef6b1190aff949140e0c79603d833668647a31.tar.gz
Add admin option to pleroma.user new. Add user existence checking to toggle_activated
Diffstat (limited to 'lib')
-rw-r--r--lib/mix/tasks/pleroma/user.ex22
1 files changed, 18 insertions, 4 deletions
diff --git a/lib/mix/tasks/pleroma/user.ex b/lib/mix/tasks/pleroma/user.ex
index 9aa569b2a..40d920866 100644
--- a/lib/mix/tasks/pleroma/user.ex
+++ b/lib/mix/tasks/pleroma/user.ex
@@ -47,7 +47,8 @@ defmodule Mix.Tasks.Pleroma.User do
name: :string,
bio: :string,
password: :string,
- moderator: :boolean
+ moderator: :boolean,
+ admin: :boolean
]
)
@@ -64,6 +65,7 @@ defmodule Mix.Tasks.Pleroma.User do
end
moderator? = Keyword.get(options, :moderator, false)
+ admin? = Keyword.get(options, :admin, false)
Mix.shell().info("""
A user will be created with the following information:
@@ -75,6 +77,7 @@ defmodule Mix.Tasks.Pleroma.User do
- name: #{name}
- bio: #{bio}
- moderator: #{if(moderator?, do: "true", else: "false")}
+ - admin: #{if(admin?, do: "true", else: "false")}
""")
proceed? = Mix.shell().yes?("Continue?")
@@ -102,9 +105,14 @@ defmodule Mix.Tasks.Pleroma.User do
run(["set", nickname, "--moderator"])
end
+ if admin? do
+ run(["set", nickname, "--admin"])
+ end
+
if generated_password? do
run(["reset_password", nickname])
end
+
else
Mix.shell().info("User will not be created.")
end
@@ -115,16 +123,22 @@ defmodule Mix.Tasks.Pleroma.User do
with %User{local: true} = user <- User.get_by_nickname(nickname) do
User.delete(user)
+ Mix.shell().info("User #{nickname} deleted.")
+ else
+ _ ->
+ Mix.shell().error("No local user #{nickname}")
end
-
- Mix.shell().info("User #{nickname} deleted.")
end
def run(["toggle_activated", nickname]) do
Mix.Task.run("app.start")
- with user <- User.get_by_nickname(nickname) do
+ with %User{local: true} = user <- User.get_by_nickname(nickname) do
User.deactivate(user, !user.info["deactivated"])
+ Mix.shell().info("Activation status of #{nickname}: #{user.info["deactivated"]}")
+ else
+ _ ->
+ Mix.shell().error("No local user #{nickname}")
end
end