From 1ed310330094ead8e68aa3ae4b09f8a1b679e6e9 Mon Sep 17 00:00:00 2001 From: Alexander Tuzaev Date: Thu, 3 Oct 2024 17:34:03 +0300 Subject: [PATCH] Changed the signature of sessions' functions so that they will be initialized only once on server run, not for every handler --- src/dream.ml | 6 +++--- src/dream.mli | 6 +++--- src/server/router.ml | 21 ++++++++------------- src/server/session.ml | 4 ++-- src/sql/session.ml | 2 +- 5 files changed, 17 insertions(+), 22 deletions(-) diff --git a/src/dream.ml b/src/dream.ml index 07b9248a..c290dea1 100644 --- a/src/dream.ml +++ b/src/dream.ml @@ -260,9 +260,9 @@ let drop_session_field = Session.drop_session_field let all_session_values = Session.all_session_values let all_session_fields = all_session_values let invalidate_session = Session.invalidate_session -let memory_sessions = Session.memory_sessions -let cookie_sessions = Session.cookie_sessions -let sql_sessions = Sql_session.sql_sessions +let memory_sessions = Session.memory_sessions () +let cookie_sessions = Session.cookie_sessions () +let sql_sessions = Sql_session.sql_sessions () let session_id = Session.session_id let session_label = Session.session_label let session_expires_at = Session.session_expires_at diff --git a/src/dream.mli b/src/dream.mli index 27117615..0c92d943 100644 --- a/src/dream.mli +++ b/src/dream.mli @@ -1583,15 +1583,15 @@ val invalidate_session : request -> unit promise (** {2 Back ends} *) -val memory_sessions : ?lifetime:float -> middleware +val memory_sessions : middleware (** Stores sessions in server memory. Passes session IDs to clients in cookies. Session data is lost when the server process exits. *) -val cookie_sessions : ?lifetime:float -> middleware +val cookie_sessions : middleware (** Stores sessions in encrypted cookies. Use {!Dream.set_secret} to be able to decrypt cookies from previous server runs. *) -val sql_sessions : ?lifetime:float -> middleware +val sql_sessions : middleware (** Stores sessions in an SQL database. Passes session IDs to clients in cookies. Must be used under {!Dream.sql_pool}. Expects a table diff --git a/src/server/router.ml b/src/server/router.ml index 49d46227..d74aa37f 100644 --- a/src/server/router.ml +++ b/src/server/router.ml @@ -26,6 +26,9 @@ type token = | Param of string | Wildcard of string +let log = + Log.sub_log "dream.router" + let rec validate route = function | (Param "")::_ -> Printf.ksprintf failwith "Empty path parameter name in '%s'" route @@ -141,19 +144,15 @@ let any pattern handler = let no_route = [] -let rec apply middlewares routes = - let rec compose handler = function - | [] -> handler - | middleware::more -> middleware @@ compose handler more - in +let rec apply pipeline routes = routes |> List.flatten |> List.map (fun (pattern, node) -> let node = match node with | Handler (method_, handler) -> - Handler (method_, compose handler middlewares) - | Scope route -> Scope (apply middlewares [route]) + Handler (method_, pipeline handler) + | Scope route -> Scope (apply pipeline [route]) in pattern, node) @@ -161,8 +160,8 @@ let under prefix routes = [strip_empty_trailing_token (parse prefix), Scope (List.flatten routes)] let scope prefix middlewares routes = - under prefix [apply middlewares routes] - + let pipeline = Message.pipeline middlewares in + under prefix [apply pipeline routes] let path_field : string list Message.field = @@ -213,10 +212,6 @@ let params_field : (string * string) list Message.field = () - -let log = - Log.sub_log "dream.router" - let missing_param request name = let message = Printf.sprintf "Dream.param: missing path parameter %S" name in log.error (fun log -> log ~request "%s" message); diff --git a/src/server/session.ml b/src/server/session.ml index 24942545..ffdc1bef 100644 --- a/src/server/session.ml +++ b/src/server/session.ml @@ -341,10 +341,10 @@ let two_weeks = module Make (Pclock : Mirage_clock.PCLOCK) = struct let now () = Ptime.to_float_s (Ptime.v (Pclock.now_d_ps ())) - let memory_sessions ?(lifetime = two_weeks) = + let memory_sessions ?(lifetime = two_weeks) () = middleware (Memory.back_end ~now lifetime) - let cookie_sessions ?(lifetime = two_weeks) = + let cookie_sessions ?(lifetime = two_weeks) () = middleware (Cookie.back_end ~now lifetime) end diff --git a/src/sql/session.ml b/src/sql/session.ml index 728fa48b..ae73c4e4 100644 --- a/src/sql/session.ml +++ b/src/sql/session.ml @@ -211,5 +211,5 @@ let back_end lifetime = { send; } -let sql_sessions ?(lifetime = Session.two_weeks) = +let sql_sessions ?(lifetime = Session.two_weeks) () = Session.middleware (back_end lifetime)