From 765671a5b0eea5f906f333f39f03289a59506bb6 Mon Sep 17 00:00:00 2001
From: lain <lain@soykaf.club>
Date: Wed, 21 Feb 2018 18:24:17 +0100
Subject: [PATCH] Add password reset task.

---
 README.md                                |  6 ++++++
 lib/mix/tasks/generate_password_reset.ex | 19 +++++++++++++++++++
 2 files changed, 25 insertions(+)
 create mode 100644 lib/mix/tasks/generate_password_reset.ex

diff --git a/README.md b/README.md
index fcf296c01..5c6753b0a 100644
--- a/README.md
+++ b/README.md
@@ -59,3 +59,9 @@ Add the following to your `dev.secret.exs` or `prod.secret.exs` if you want to p
       proxy_url: "127.0.0.1:8123"
 
 This is useful for running pleroma inside Tor or i2p.
+
+## Admin Tasks
+
+### Password reset
+
+Run `mix generate_password_reset username` to generate a password reset link that you can then send to the user.
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
-- 
GitLab