package sihl
The modular functional web framework
Install
Dune Dependency
Authors
Maintainers
Sources
sihl-0.1.4.tbz
sha256=49fe887d05083b37523cd6e7ca35239822c561fe7109dd383c30aeb4259a7b98
sha512=4135ad42a75fb9adc3e853a466b696d9ee6d7a9d8acf0cee9fd5f5485679a517f524ce704e2d153df4a7c4f1d14df9f94ab2a8fbe5b36e744b505daab1d40f3d
doc/src/sihl.middleware/middleware_session.ml.html
Source file middleware_session.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
open Base open Lwt.Syntax module Make (SessionService : Session.Service.Sig.SERVICE) = struct let m ?( = "session_key") () = let filter handler ctx = match Http.Req.cookie_data ctx ~key:cookie_key with | Some session_key -> ( (* A session cookie was found *) let* session = SessionService.find_opt ctx ~key:session_key in match session with | Some session -> let* session = if Session.is_expired (Ptime_clock.now ()) session then ( Logs.debug (fun m -> m "SESSION: Session expired, creating new one"); let* session = SessionService.create ctx [] in Lwt.return session ) else Lwt.return session in let ctx = SessionService.add_to_ctx session ctx in handler ctx | None -> let* session = SessionService.create ctx [] in let ctx = SessionService.add_to_ctx session ctx in let* res = handler ctx in res |> Http.Res.set_cookie ~key:cookie_key ~data:session.key |> Lwt.return ) | None -> (* No session cookie found *) let* session = SessionService.create ctx [] in let ctx = SessionService.add_to_ctx session ctx in let* res = handler ctx in res |> Http.Res.set_cookie ~key:cookie_key ~data:session.key |> Lwt.return in Middleware_core.create ~name:"session" filter end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>