Session
#...
get "/login", SessionController, :new
get "/logout", SessionController, :delete
resources "/sessions", SessionController, only: [:new, :create, :delete], singleton: true
#...defmodule DiscussWeb.SessionController do
use DiscussWeb, :controller
alias Discuss.Accounts
def new(conn, _) do
render(conn, "new.html")
end
def delete(conn, _) do
conn
|> configure_session(drop: true)
|> put_flash(:success, "Successfully signed out")
|> redirect(to: "/")
end
def create(conn, %{"user" => %{"email" => email, "password" => password}}) do
case Accounts.authenticate_by_email_password(email, password) do #write this ft in Accounts
{:ok, user} ->
conn
|> put_flash(:info, "Welcome back!")
|> put_session(:user_id, user.id) #Use an Auth Plug to lookup user
|> configure_session(renew: true)
|> redirect(to: "/")
{:error, :unauthorized} ->
conn
|> put_flash(:info, "Bad email/password")
|> redirect(to: Routes.session_path(conn, :new))
{:error, :not_found} ->
conn
|> put_flash(:info, "Account not found!")
|> redirect(to: Routes.session_path(conn, :new))
end
end
endPlug
Last updated