63 lines
1.7 KiB
Elixir
63 lines
1.7 KiB
Elixir
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
|