package sihl
The modular functional web framework
Install
Dune Dependency
Authors
Maintainers
Sources
sihl-0.1.3.tbz
sha256=3d1acdd1eae24a7131033656f90b5d20c1621e6ef92957edf88a09b8b5f2d9e9
sha512=d224f54e20a9465c7a03d534dadcb2b9a181ae87c13731840db945aab37534f6f3982c5cb25a197e90c17d8772da062b19fa92bb93ed53a8b736c3776a7776db
doc/src/sihl.authn/authn_service.ml.html
Source file authn_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
open Lwt.Syntax module Sig = Authn_service_sig exception Exception of string module Make (Log : Log.Service.Sig.SERVICE) (SessionService : Session.Service.Sig.SERVICE) (UserService : User.Service.Sig.SERVICE) : Sig.SERVICE = struct let find_user_in_session_opt ctx = let* user_id = SessionService.get ctx ~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 = let* user_id = SessionService.get ctx ~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 = SessionService.set ctx ~key:"authn" ~value:(User.id user) let unauthenticate_session ctx = SessionService.unset ctx ~key:"authn" let start ctx = Lwt.return ctx let stop _ = Lwt.return () let lifecycle = Core.Container.Lifecycle.make "authn" ~start ~stop ~dependencies:[ SessionService.lifecycle; UserService.lifecycle ] end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>