mirror of
https://git.pleroma.social/pleroma/pleroma.git
synced 2025-01-09 00:35:30 +00:00
Add password reset task.
This commit is contained in:
parent
eec6a87dbb
commit
765671a5b0
2 changed files with 25 additions and 0 deletions
|
@ -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"
|
proxy_url: "127.0.0.1:8123"
|
||||||
|
|
||||||
This is useful for running pleroma inside Tor or i2p.
|
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.
|
||||||
|
|
19
lib/mix/tasks/generate_password_reset.ex
Normal file
19
lib/mix/tasks/generate_password_reset.ex
Normal file
|
@ -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
|
Loading…
Reference in a new issue