feat(auth): add auth through phx.gen.auth
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
defmodule SlaxWeb.Router do
|
||||
use SlaxWeb, :router
|
||||
|
||||
import SlaxWeb.UserAuth
|
||||
|
||||
pipeline :browser do
|
||||
plug :accepts, ["html"]
|
||||
plug :fetch_session
|
||||
@@ -8,21 +10,13 @@ defmodule SlaxWeb.Router do
|
||||
plug :put_root_layout, html: {SlaxWeb.Layouts, :root}
|
||||
plug :protect_from_forgery
|
||||
plug :put_secure_browser_headers
|
||||
plug :fetch_current_user
|
||||
end
|
||||
|
||||
pipeline :api do
|
||||
plug :accepts, ["json"]
|
||||
end
|
||||
|
||||
scope "/", SlaxWeb do
|
||||
pipe_through :browser
|
||||
|
||||
get "/home", PageController, :home
|
||||
live "/", ChatRoomLive
|
||||
live "/rooms/:id", ChatRoomLive
|
||||
live "/rooms/:id/edit", ChatRoomLive.Edit
|
||||
end
|
||||
|
||||
# Other scopes may use custom stacks.
|
||||
# scope "/api", SlaxWeb do
|
||||
# pipe_through :api
|
||||
@@ -44,4 +38,45 @@ defmodule SlaxWeb.Router do
|
||||
forward "/mailbox", Plug.Swoosh.MailboxPreview
|
||||
end
|
||||
end
|
||||
|
||||
## Authentication routes
|
||||
|
||||
scope "/", SlaxWeb do
|
||||
pipe_through [:browser, :redirect_if_user_is_authenticated]
|
||||
|
||||
live_session :redirect_if_user_is_authenticated,
|
||||
on_mount: [{SlaxWeb.UserAuth, :redirect_if_user_is_authenticated}] do
|
||||
live "/users/register", UserRegistrationLive, :new
|
||||
live "/users/log_in", UserLoginLive, :new
|
||||
live "/users/reset_password", UserForgotPasswordLive, :new
|
||||
live "/users/reset_password/:token", UserResetPasswordLive, :edit
|
||||
end
|
||||
|
||||
post "/users/log_in", UserSessionController, :create
|
||||
end
|
||||
|
||||
scope "/", SlaxWeb do
|
||||
pipe_through [:browser, :require_authenticated_user]
|
||||
|
||||
live_session :require_authenticated_user,
|
||||
on_mount: [{SlaxWeb.UserAuth, :ensure_authenticated}] do
|
||||
live "/", ChatRoomLive
|
||||
live "/rooms/:id", ChatRoomLive
|
||||
live "/rooms/:id/edit", ChatRoomLive.Edit
|
||||
live "/users/settings", UserSettingsLive, :edit
|
||||
live "/users/settings/confirm_email/:token", UserSettingsLive, :confirm_email
|
||||
end
|
||||
end
|
||||
|
||||
scope "/", SlaxWeb do
|
||||
pipe_through [:browser]
|
||||
|
||||
delete "/users/log_out", UserSessionController, :delete
|
||||
|
||||
live_session :current_user,
|
||||
on_mount: [{SlaxWeb.UserAuth, :mount_current_user}] do
|
||||
live "/users/confirm/:token", UserConfirmationLive, :edit
|
||||
live "/users/confirm", UserConfirmationInstructionsLive, :new
|
||||
end
|
||||
end
|
||||
end
|
||||
|
Reference in New Issue
Block a user