defmodule BackendWeb.Endpoint do use Phoenix.Endpoint, otp_app: :backend use Appsignal.Phoenix socket("/socket", BackendWeb.UserSocket, websocket: true, longpoll: false ) # Serve at "/" the static files from "priv/static" directory. # # You should set gzip to true if you are running phx.digest # when deploying your static files in production. plug(Plug.Static, at: "/", from: :backend, gzip: false, only: ~w(css fonts images js favicon.ico robots.txt) ) # Code reloading can be explicitly enabled under the # :code_reloader configuration of your endpoint. if code_reloading? do plug(Phoenix.CodeReloader) end plug(Plug.RequestId) plug(Plug.Logger) plug(Plug.Parsers, parsers: [:urlencoded, :multipart, :json], pass: ["*/*"], json_decoder: Phoenix.json_library() ) plug(Plug.MethodOverride) plug(Plug.Head) # 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. plug(Plug.Session, store: :cookie, key: "_backend_key", signing_salt: "HJa1j4FI" ) plug(Corsica, origins: ["http://localhost:3000", ~r{^https://(.*\.?)fediverse\.space$}, ~r{^https://(.*\.?)fediverse-space\.netlify\.app$}], allow_headers: ["content-type", "token"] ) plug(BackendWeb.Router) end