How to Use Built-In Phoenix Authentication: Difference between revisions
From ElixirBlocks
(Created page with "{{In_progress}} <hr/> Phoenix has a built in authentication generator. To use the feature, you can run the following command: <source> mix phx.gen.auth Accounts User users </source> You are asked to choose the form of authentication that you want. The 2 choices are LiveView authentication or Controller based authentication. ==LiveView Authentication== ==Controller Based Authentication==") |
No edit summary |
||
(One intermediate revision by the same user not shown) | |||
Line 14: | Line 14: | ||
==LiveView Authentication== | ==LiveView Authentication== | ||
===How to Restrict a Route to an Authenticated User=== | |||
In the example below is a route named /sandbox. | |||
'''Route''' | |||
<source> | |||
scope "/", AppWeb do | |||
pipe_through [:browser, :require_authenticated_user] #:require_authenticated_user | |||
live "/sandbox", SandboxLive | |||
end | |||
</source> | |||
'''Component''' | |||
<source> | |||
defmodule AppWeb.SandboxLive do | |||
use AppWeb, :live_view | |||
on_mount {AppWeb.UserAuth, :ensure_authenticated} | |||
def mount(_params, _session, socket) do | |||
{:ok, socket} | |||
end | |||
def render(assigns) do | |||
~H""" | |||
SANDBOX | |||
<div><% @current_user.id %></div> | |||
""" | |||
end | |||
end | |||
</source> | |||
===Check for Authenticating of Individual Heex Modules=== | |||
<source> | |||
defmodule AppWeb.PageLive do | |||
use AppWeb, :live_view | |||
on_mount {AppWeb.UserAuth, :mount_current_user } | |||
def mount(_params, _session, socket) do | |||
{:ok, socket} | |||
end | |||
def child_panel(assigns) do | |||
~H""" | |||
<div> | |||
<%= if @auth_check do %> <!--This works--> | |||
<p> This is only viewed if authenticated</p> | |||
<% end %> | |||
<p> THis is viewed to all users</p> | |||
</div> | |||
""" | |||
end | |||
def render(assigns) do | |||
~H""" | |||
<div> | |||
<p> Hello World! Do you see the text below?</p> | |||
<%= if @current_user do %> | |||
<p> This is only viewed if authenticated</p> | |||
<% end %> | |||
<.child_panel auth_check={@current_user}></.child_panel> <!-- This works--> | |||
</div> | |||
""" | |||
end | |||
end | |||
</source> | |||
==Controller Based Authentication== | ==Controller Based Authentication== |
Latest revision as of 20:47, 3 December 2023
This page is in progress
Phoenix has a built in authentication generator.
To use the feature, you can run the following command:
mix phx.gen.auth Accounts User users
You are asked to choose the form of authentication that you want. The 2 choices are LiveView authentication or Controller based authentication.
LiveView Authentication
How to Restrict a Route to an Authenticated User
In the example below is a route named /sandbox.
Route
scope "/", AppWeb do pipe_through [:browser, :require_authenticated_user] #:require_authenticated_user live "/sandbox", SandboxLive end
Component
defmodule AppWeb.SandboxLive do use AppWeb, :live_view on_mount {AppWeb.UserAuth, :ensure_authenticated} def mount(_params, _session, socket) do {:ok, socket} end def render(assigns) do ~H""" SANDBOX <div><% @current_user.id %></div> """ end end
Check for Authenticating of Individual Heex Modules
defmodule AppWeb.PageLive do use AppWeb, :live_view on_mount {AppWeb.UserAuth, :mount_current_user } def mount(_params, _session, socket) do {:ok, socket} end def child_panel(assigns) do ~H""" <div> <%= if @auth_check do %> <!--This works--> <p> This is only viewed if authenticated</p> <% end %> <p> THis is viewed to all users</p> </div> """ end def render(assigns) do ~H""" <div> <p> Hello World! Do you see the text below?</p> <%= if @current_user do %> <p> This is only viewed if authenticated</p> <% end %> <.child_panel auth_check={@current_user}></.child_panel> <!-- This works--> </div> """ end end