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.authn/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
open Lwt.Syntax module Core = Sihl_core module Session = Sihl_session module User = Sihl_user exception Exception of string let log_src = Logs.Src.create ~doc:"authn" "sihl.service.authn" module Logs = (val Logs.src_log log_src : Logs.LOG) module Make (SessionService : Session.Sig.SERVICE) (UserService : User.Sig.SERVICE) : Sig.SERVICE = struct let find_user_in_session_opt ctx session = let* user_id = SessionService.get ctx session ~key:"authn" in match user_id with | None -> Lwt.return None | Some user_id -> UserService.find_opt ctx ~user_id ;; let find_user_in_session ctx session = let* user_id = SessionService.get ctx session ~key:"authn" in match user_id with | None -> raise @@ Exception "No user found in current session" | Some user_id -> UserService.find ctx ~user_id ;; let authenticate_session ctx user session = SessionService.set ctx session ~key:"authn" ~value:(User.id user) ;; let unauthenticate_session ctx session = SessionService.unset ctx session ~key:"authn" let start ctx = Lwt.return ctx let stop _ = Lwt.return () let lifecycle = Core.Container.Lifecycle.create "authn" ~start ~stop ~dependencies:[ SessionService.lifecycle; UserService.lifecycle ] ;; let register () = Core.Container.Service.create lifecycle end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>