defmodule SimpleshopThemeWeb.Endpoint do use Phoenix.Endpoint, otp_app: :simpleshop_theme # 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: "_simpleshop_theme_key", signing_salt: "JNwRcD7y", same_site: "Lax" ] socket "/live", Phoenix.LiveView.Socket, websocket: [connect_info: [session: @session_options]], longpoll: [connect_info: [session: @session_options]] # 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`. # # Cache headers: 1 year for all static assets. Digested assets (with hash # in filename) use `immutable`. Fonts/mockups/images rarely change and # benefit from aggressive caching. plug Plug.Static, at: "/", from: :simpleshop_theme, gzip: not code_reloading?, only: SimpleshopThemeWeb.static_paths(), cache_control_for_etags: "public, max-age=31536000, immutable" if Code.ensure_loaded?(Tidewave) do plug Tidewave, allow_remote_access: true end # Code reloading can be explicitly enabled under the # :code_reloader configuration of your endpoint. if code_reloading? do socket "/phoenix/live_reload/socket", Phoenix.LiveReloader.Socket plug Phoenix.LiveReloader plug Phoenix.CodeReloader plug Phoenix.Ecto.CheckRepoStatus, otp_app: :simpleshop_theme end plug Phoenix.LiveDashboard.RequestLogger, param_key: "request_logger", cookie_key: "request_logger" plug Plug.RequestId plug Plug.Telemetry, event_prefix: [:phoenix, :endpoint] plug Plug.Parsers, parsers: [:urlencoded, :multipart, :json], pass: ["*/*"], body_reader: {SimpleshopThemeWeb.Plugs.CacheRawBody, :read_body, []}, json_decoder: Phoenix.json_library() plug Plug.MethodOverride plug Plug.Head plug Plug.Session, @session_options plug SimpleshopThemeWeb.Router end