server/lib/boardwise_web/router.ex

54 lines
1.4 KiB
Elixir
Raw Normal View History

2023-11-30 17:25:00 +00:00
defmodule BoardWiseWeb.Router do
use BoardWiseWeb, :router
2023-11-28 17:50:13 +00:00
pipeline :browser do
plug :accepts, ["html"]
plug :fetch_session
plug :fetch_live_flash
2023-11-30 17:25:00 +00:00
plug :put_root_layout, html: {BoardWiseWeb.Layouts, :root}
2023-11-28 17:50:13 +00:00
plug :protect_from_forgery
plug :put_secure_browser_headers
end
pipeline :react do
plug :put_root_layout, html: {BoardWiseWeb.Layouts, :react}
end
2023-11-28 17:50:13 +00:00
pipeline :api do
plug :accepts, ["json"]
end
2023-11-30 17:25:00 +00:00
scope "/", BoardWiseWeb do
2023-11-28 17:50:13 +00:00
pipe_through :browser
end
# Other scopes may use custom stacks.
2023-11-30 17:25:00 +00:00
# scope "/api", BoardWiseWeb do
2023-11-28 17:50:13 +00:00
# pipe_through :api
# end
# Enable LiveDashboard and Swoosh mailbox preview in development
2023-11-30 17:25:00 +00:00
if Application.compile_env(:boardwise, :dev_routes) do
2023-11-28 17:50:13 +00:00
# If you want to use the LiveDashboard in production, you should put
# it behind authentication and allow only admins to access it.
# If your application does not have an admins-only section yet,
# you can use Plug.BasicAuth to set up some basic authentication
# as long as you are also using SSL (which you should anyway).
import Phoenix.LiveDashboard.Router
scope "/dev" do
pipe_through :browser
2023-11-30 17:25:00 +00:00
live_dashboard "/dashboard", metrics: BoardWiseWeb.Telemetry
2023-11-28 17:50:13 +00:00
forward "/mailbox", Plug.Swoosh.MailboxPreview
end
end
# A catch-all that defers to the React app router.
scope "/", BoardWiseWeb do
pipe_through [:browser, :react]
get "/*path", ReactController, :mount
end
2023-11-28 17:50:13 +00:00
end