From 7d54821399dc85c789293cd7b08b04bea92c482f Mon Sep 17 00:00:00 2001 From: Kayla Firestack Date: Thu, 14 Nov 2024 08:49:48 -0500 Subject: [PATCH] chore(ex/skate_web/endpoint): pull `Plug.Session` options into compile time constant (#2894) Aligns our implementation with the `phx.new` template - https://github.com/phoenixframework/phoenix/blob/main/installer/templates/phx_web/endpoint.ex#L7-L12 - https://github.com/phoenixframework/phoenix/blob/main/installer/templates/phx_web/endpoint.ex#L51 --- lib/skate_web/endpoint.ex | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/lib/skate_web/endpoint.ex b/lib/skate_web/endpoint.ex index 4cf7cb122..12d941d04 100644 --- a/lib/skate_web/endpoint.ex +++ b/lib/skate_web/endpoint.ex @@ -2,8 +2,21 @@ defmodule SkateWeb.Endpoint do use Sentry.PlugCapture use Phoenix.Endpoint, otp_app: :skate + # 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: "_skate_key", + signing_salt: "jkUgGkwy", + same_site: "Lax" + ] + socket "/socket", SkateWeb.UserSocket, - websocket: [check_origin: Application.compile_env(:skate, :websocket_check_origin, false)], + websocket: [ + connect_info: [session: @session_options], + check_origin: Application.compile_env(:skate, :websocket_check_origin, false) + ], longpoll: false # Serve at "/" the static files from "priv/static" directory. @@ -36,14 +49,7 @@ defmodule SkateWeb.Endpoint do plug Sentry.PlugContext 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: "_skate_key", - signing_salt: "jkUgGkwy" + plug Plug.Session, @session_options plug SkateWeb.Router end