defmodule BackendWeb.Endpoint do use Phoenix.Endpoint, otp_app: :backend # The session will be stored in the cookie and signed, # this means its contents can be read but not tampered with. # Set :encryption_salt if you would also like to encrypt it. @session_options [ store: :cookie, key: "_backend_key", signing_salt: "AnIFBp4s", same_site: "Lax" ] socket("/live", Phoenix.LiveView.Socket, websocket: [connect_info: [session: @session_options]], longpoll: [connect_info: [session: @session_options]] ) socket("/socket", BackendWeb.UserSocket, websocket: true, longpoll: false ) # Serve at "/" the static files from "priv/static" directory. # # When code reloading is disabled (e.g., in production), # the `gzip` option is enabled to serve compressed # static files generated by running `phx.digest`. plug(Plug.Static, at: "/", from: :backend, gzip: not code_reloading?, only: BackendWeb.static_paths(), raise_on_missing_only: code_reloading? ) # Code reloading can be explicitly enabled under the # :code_reloader configuration of your endpoint. if code_reloading? do plug(Phoenix.CodeReloader) end plug(Phoenix.LiveDashboard.RequestLogger, param_key: "request_logger", cookie_key: "request_logger" ) plug(Plug.RequestId) plug(BackendWeb.Plugs.HealthCheckLogger) plug(BackendWeb.Plugs.Telemetry, event_prefix: [:phoenix, :endpoint]) plug(Plug.Parsers, parsers: [:urlencoded, :multipart, :json], pass: ["*/*"], json_decoder: Phoenix.json_library() ) plug(Plug.MethodOverride) plug(Plug.Head) plug(Plug.Session, @session_options) plug(BackendWeb.Router) end