logo

pleroma

My custom branche(s) on git.pleroma.social/pleroma/pleroma
commit: 765671a5b0eea5f906f333f39f03289a59506bb6
parent: eec6a87dbb1186349c766c88829ad121588bb43b
Author: lain <lain@soykaf.club>
Date:   Wed, 21 Feb 2018 18:24:17 +0100

Add password reset task.

Diffstat:

MREADME.md6++++++
Alib/mix/tasks/generate_password_reset.ex19+++++++++++++++++++
2 files changed, 25 insertions(+), 0 deletions(-)

diff --git 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 @@ -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