aboutsummaryrefslogtreecommitdiff
path: root/lib/mix/tasks
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2018-02-21 18:34:19 +0100
committerlain <lain@soykaf.club>2018-02-21 18:34:19 +0100
commit94db9ac4dba6ba02fcae1b9055b532818cf787c7 (patch)
tree0b6189c60adbca5e0ea6b9aded01dccfbbc35755 /lib/mix/tasks
parenta06b9a3e0b5639dfc3a975c7a5f3ea11a05a286f (diff)
parente98aeabbdebee8f6c9a10d0c9e3f48c1031172cb (diff)
downloadpleroma-94db9ac4dba6ba02fcae1b9055b532818cf787c7.tar.gz
Merge branch 'develop' into feature/activitypub
Diffstat (limited to 'lib/mix/tasks')
-rw-r--r--lib/mix/tasks/generate_password_reset.ex19
-rw-r--r--lib/mix/tasks/make_moderator.ex27
2 files changed, 46 insertions, 0 deletions
diff --git a/lib/mix/tasks/generate_password_reset.ex b/lib/mix/tasks/generate_password_reset.ex
new file mode 100644
index 000000000..b968b1f98
--- /dev/null
+++ b/lib/mix/tasks/generate_password_reset.ex
@@ -0,0 +1,19 @@
+defmodule Mix.Tasks.GeneratePasswordReset do
+ use Mix.Task
+ import Mix.Ecto
+ alias Pleroma.{Repo, User}
+
+ @shortdoc "Generate password reset link for user"
+ def run([nickname]) do
+ Mix.Task.run("app.start")
+
+ with %User{local: true} = user <- User.get_by_nickname(nickname),
+ {:ok, token} <- Pleroma.PasswordResetToken.create_token(user) do
+ IO.puts "Generated password reset token for #{user.nickname}"
+ IO.puts "Url: #{Pleroma.Web.Router.Helpers.util_url(Pleroma.Web.Endpoint, :show_password_reset, token.token)}"
+ else
+ _ ->
+ IO.puts "No local user #{nickname}"
+ end
+ end
+end
diff --git a/lib/mix/tasks/make_moderator.ex b/lib/mix/tasks/make_moderator.ex
new file mode 100644
index 000000000..a76b54f40
--- /dev/null
+++ b/lib/mix/tasks/make_moderator.ex
@@ -0,0 +1,27 @@
+defmodule Mix.Tasks.SetModerator do
+ use Mix.Task
+ import Mix.Ecto
+ alias Pleroma.{Repo, User}
+
+ @shortdoc "Set moderator status"
+ def run([nickname | rest]) do
+ ensure_started(Repo, [])
+
+ moderator = case rest do
+ [moderator] -> moderator == "true"
+ _ -> true
+ end
+
+ with %User{local: true} = user <- User.get_by_nickname(nickname) do
+ info = user.info
+ |> Map.put("is_moderator", !!moderator)
+ cng = User.info_changeset(user, %{info: info})
+ user = Repo.update!(cng)
+
+ IO.puts "Moderator status of #{nickname}: #{user.info["is_moderator"]}"
+ else
+ _ ->
+ IO.puts "No local user #{nickname}"
+ end
+ end
+end