cannery/lib/cannery_web/controllers/user_settings_controller.ex

95 lines
2.9 KiB
Elixir
Raw Normal View History

2021-03-11 21:12:55 -05:00
defmodule CanneryWeb.UserSettingsController do
use CanneryWeb, :controller
alias Cannery.Accounts
2022-01-21 20:36:25 -05:00
alias CanneryWeb.{HomeLive, UserAuth}
2021-03-11 21:12:55 -05:00
plug :assign_email_and_password_changesets
def edit(conn, _params) do
render(conn, "edit.html")
end
def update(conn, %{"action" => "update_email"} = params) do
%{"current_password" => password, "user" => user_params} = params
user = conn.assigns.current_user
case Accounts.apply_user_email(user, password, user_params) do
{:ok, applied_user} ->
Accounts.deliver_update_email_instructions(
applied_user,
user.email,
&Routes.user_settings_url(conn, :confirm_email, &1)
)
conn
|> put_flash(
:info,
2022-02-09 00:13:01 -05:00
dgettext(
"prompts",
"A link to confirm your email change has been sent to the new address."
)
2021-03-11 21:12:55 -05:00
)
|> redirect(to: Routes.user_settings_path(conn, :edit))
{:error, changeset} ->
render(conn, "edit.html", email_changeset: changeset)
end
end
def update(conn, %{"action" => "update_password"} = params) do
%{"current_password" => password, "user" => user_params} = params
user = conn.assigns.current_user
case Accounts.update_user_password(user, password, user_params) do
{:ok, user} ->
conn
2022-02-09 00:13:01 -05:00
|> put_flash(:info, dgettext("prompts", "Password updated successfully."))
2021-03-11 21:12:55 -05:00
|> put_session(:user_return_to, Routes.user_settings_path(conn, :edit))
|> UserAuth.log_in_user(user)
{:error, changeset} ->
render(conn, "edit.html", password_changeset: changeset)
end
end
def confirm_email(conn, %{"token" => token}) do
case Accounts.update_user_email(conn.assigns.current_user, token) do
:ok ->
conn
2022-02-09 00:13:01 -05:00
|> put_flash(:info, dgettext("prompts", "Email changed successfully."))
2021-03-11 21:12:55 -05:00
|> redirect(to: Routes.user_settings_path(conn, :edit))
:error ->
conn
2022-02-09 00:13:01 -05:00
|> put_flash(
:error,
dgettext("errors", "Email change link is invalid or it has expired.")
)
2021-03-11 21:12:55 -05:00
|> redirect(to: Routes.user_settings_path(conn, :edit))
end
end
2022-02-12 00:34:11 -05:00
def delete(%{assigns: %{current_user: current_user}} = conn, %{"id" => user_id}) do
if user_id == current_user.id do
current_user |> Accounts.delete_user!(current_user)
2021-09-10 21:37:17 -04:00
conn
2022-02-09 00:13:01 -05:00
|> put_flash(:error, dgettext("prompts", "Your account has been deleted"))
2022-01-21 20:36:25 -05:00
|> redirect(to: Routes.live_path(conn, HomeLive))
2021-09-10 21:37:17 -04:00
else
conn
2022-02-09 00:13:01 -05:00
|> put_flash(:error, dgettext("errors", "Unable to delete user"))
2021-09-10 21:37:17 -04:00
|> redirect(to: Routes.user_settings_path(conn, :edit))
end
end
2021-03-11 21:12:55 -05:00
defp assign_email_and_password_changesets(conn, _opts) do
user = conn.assigns.current_user
conn
|> assign(:email_changeset, Accounts.change_user_email(user))
|> assign(:password_changeset, Accounts.change_user_password(user))
end
end