defmodule <%= inspect context.web_module %>.<%= inspect Module.concat(schema.web_namespace, schema.alias) %>SessionController do use <%= inspect context.web_module %>, :controller alias <%= inspect context.module %> alias <%= inspect auth_module %><%= if live? do %> def create(conn, %{"_action" => "registered"} = params) do create(conn, params, "Account created successfully!") end def create(conn, %{"_action" => "password_updated"} = params) do conn |> put_session(:<%= schema.singular %>_return_to, ~p"<%= schema.route_prefix %>/settings") |> create(params, "Password updated successfully!") end def create(conn, params) do create(conn, params, "Welcome back!") end defp create(conn, %{"<%= schema.singular %>" => <%= schema.singular %>_params}, info) do %{"email" => email, "password" => password} = <%= schema.singular %>_params if <%= schema.singular %> = <%= inspect context.alias %>.get_<%= schema.singular %>_by_email_and_password(email, password) do conn |> put_flash(:info, info) |> <%= inspect schema.alias %>Auth.log_in_<%= schema.singular %>(<%= schema.singular %>, <%= schema.singular %>_params) else # In order to prevent user enumeration attacks, don't disclose whether the email is registered. conn |> put_flash(:error, "Invalid email or password") |> put_flash(:email, String.slice(email, 0, 160)) |> redirect(to: ~p"<%= schema.route_prefix %>/log_in") end end<% else %> def new(conn, _params) do render(conn, :new, error_message: nil) end def create(conn, %{"<%= schema.singular %>" => <%= schema.singular %>_params}) do %{"email" => email, "password" => password} = <%= schema.singular %>_params if <%= schema.singular %> = <%= inspect context.alias %>.get_<%= schema.singular %>_by_email_and_password(email, password) do conn |> put_flash(:info, "Welcome back!") |> <%= inspect schema.alias %>Auth.log_in_<%= schema.singular %>(<%= schema.singular %>, <%= schema.singular %>_params) else # In order to prevent user enumeration attacks, don't disclose whether the email is registered. render(conn, :new, error_message: "Invalid email or password") end end<% end %> def delete(conn, _params) do conn |> put_flash(:info, "Logged out successfully.") |> <%= inspect schema.alias %>Auth.log_out_<%= schema.singular %>() end end