philomena/lib/philomena_web/controllers/registration/password_controller.ex

25 lines
776 B
Elixir

defmodule PhilomenaWeb.Registration.PasswordController do
use PhilomenaWeb, :controller
alias Philomena.Users
alias PhilomenaWeb.UserAuth
plug PhilomenaWeb.CompromisedPasswordCheckPlug when action in [:update]
def update(conn, %{"current_password" => password, "user" => user_params}) do
user = conn.assigns.current_user
case Users.update_user_password(user, password, user_params) do
{:ok, user} ->
conn
|> put_flash(:info, "Password updated successfully.")
|> put_session(:user_return_to, ~p"/registrations/edit")
|> UserAuth.log_in_user(user)
{:error, _changeset} ->
conn
|> put_flash(:error, "Failed to update password.")
|> redirect(to: ~p"/registrations/edit")
end
end
end