package sihl
The modular functional web framework
Install
Dune Dependency
Authors
Maintainers
Sources
sihl-queue-0.1.8.tbz
sha256=e77ffae26dac04e446ff07854de68a03edfd05031b5cb0dbcb6dc4a96e2d1c8e
sha512=7682c55136dbb8c68517ccd2c157a3556d966cb8565d15cf21ab270f92ea7e9ee5d3ac1479ba2e34a80f3052ca5dd1a74e964a8764c2164e3e71e9048fcdf51b
doc/src/sihl.session/service.ml.html
Source file service.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 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
module Core = Sihl_core open Lwt.Syntax let log_src = Logs.Src.create ~doc:"session" "sihl.service.session" module Logs = (val Logs.src_log log_src : Logs.LOG) let ctx_key : string Core.Ctx.key = Core.Ctx.create_key () module Repo = Repo module Make (Repo : Sig.REPO) : Sig.SERVICE = struct let make ?expire_date now = let open Model in match expire_date, default_expiration_date now with | Some expire_date, _ -> Some { key = Core.Random.base64 ~nr:10; data = Map.empty; expire_date } | None, Some expire_date -> Some { key = Core.Random.base64 ~nr:10; data = Map.empty; expire_date } | None, None -> None ;; let create ctx data = let empty_session = match make (Ptime_clock.now ()) with | Some session -> session | None -> Logs.err (fun m -> m "SESSION: Can not create session, failed to create validity time"); raise (Model.Exception "Can not set session validity time") in let session = List.fold_left (fun session (key, value) -> Model.set ~key ~value session) empty_session data in let* () = Repo.insert ctx session in Lwt.return session ;; let find_opt = Repo.find_opt let find ctx ~key = let* session = Repo.find_opt ctx ~key in match session with | Some session -> Lwt.return session | None -> Logs.err (fun m -> m "SESSION: Session with key %s not found in database" key); raise (Model.Exception "Session not found") ;; let find_all = Repo.find_all let set ctx session ~key ~value = let session_key = Model.key session in let* session = find ctx ~key:session_key in let session = Model.set ~key ~value session in Repo.update ctx session ;; let unset ctx session ~key = let session_key = Model.key session in let* session = find ctx ~key:session_key in let session = Model.remove ~key session in Repo.update ctx session ;; let get ctx session ~key = let session_key = Model.key session in let* session = find ctx ~key:session_key in Model.get key session |> Lwt.return ;; let start ctx = Repo.register_migration (); Repo.register_cleaner (); Lwt.return ctx ;; let stop _ = Lwt.return () let lifecycle = Core.Container.Lifecycle.create "session" ~start ~stop let register () = Core.Container.Service.create lifecycle end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>