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.token/token_service.ml.html
Source file token_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
open Base open Lwt.Syntax module Sig = Token_service_sig module Repo = Token_service_repo module Make (Log : Log.Service.Sig.SERVICE) (RandomService : Utils.Random.Service.Sig.SERVICE) (Repo : Sig.REPOSITORY) : Sig.SERVICE = struct let find_opt ctx value = Repo.find_opt ctx ~value let find ctx value = let* token = find_opt ctx value in match token with | Some token -> Lwt.return token | None -> raise (Token_core.Exception (Printf.sprintf "Token %s not found" value)) let make ~id ~data ~kind ?(expires_in = Utils.Time.OneDay) ?now () = let value = RandomService.base64 ~bytes:80 in let expires_in = Utils.Time.duration_to_span expires_in in let now = Option.value ~default:(Ptime_clock.now ()) now in let expires_at = Option.value_exn (Ptime.add_span now expires_in) in let status = Token_core.Status.Active in let created_at = Ptime_clock.now () in Token_core.make ~id ~value ~data ~kind ~status ~expires_at ~created_at let create ctx ~kind ?data ?expires_in () = let expires_in = Option.value ~default:Utils.Time.OneDay expires_in in let id = Data.Id.random () |> Data.Id.to_string in let token = make ~id ~kind ~data ~expires_in () in let* () = Repo.insert ctx ~token in let value = Token_core.value token in find ctx value let start ctx = let () = Repo.register_migration () in let () = Repo.register_cleaner () in Lwt.return ctx let stop _ = Lwt.return () let lifecycle = Core.Container.Lifecycle.make "token" ~start ~stop end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>