Apply 2 suggestion(s) to 2 file(s)
[akkoma] / lib / pleroma / web / twitter_api / controllers / password_controller.ex
1 # Pleroma: A lightweight social networking server
2 # Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/>
3 # SPDX-License-Identifier: AGPL-3.0-only
4
5 defmodule Pleroma.Web.TwitterAPI.PasswordController do
6 @moduledoc """
7 The module containts functions for reset password.
8 """
9
10 use Pleroma.Web, :controller
11
12 require Logger
13
14 alias Pleroma.PasswordResetToken
15 alias Pleroma.Repo
16 alias Pleroma.User
17
18 def reset(conn, %{"token" => token}) do
19 with %{used: false} = token <- Repo.get_by(PasswordResetToken, %{token: token}),
20 false <- PasswordResetToken.expired?(token),
21 %User{} = user <- User.get_cached_by_id(token.user_id) do
22 render(conn, "reset.html", %{
23 token: token,
24 user: user
25 })
26 else
27 _e -> render(conn, "invalid_token.html")
28 end
29 end
30
31 def do_reset(conn, %{"data" => data}) do
32 with {:ok, _} <- PasswordResetToken.reset_password(data["token"], data) do
33 render(conn, "reset_success.html")
34 else
35 _e -> render(conn, "reset_failed.html")
36 end
37 end
38 end