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_core.ml.html
Source file token_core.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
open Base exception Exception of string module Status = struct type t = Active | Inactive [@@deriving yojson, show, eq] let to_string = function Active -> "active" | Inactive -> "inactive" let of_string str = match str with | "active" -> Ok Active | "inactive" -> Ok Inactive | _ -> Error (Printf.sprintf "Invalid token status %s provided" str) end type t = { id : string; value : string; data : string option; kind : string; status : Status.t; expires_at : Ptime.t; created_at : Ptime.t; } [@@deriving fields, show, eq] let make ~id ~value ~data ~kind ~status ~expires_at ~created_at = { id; value; data; kind; status; expires_at; created_at } let alco = Alcotest.testable pp equal let t = let encode m = let status = Status.to_string m.status in Ok ( m.id, (m.value, (m.data, (m.kind, (status, (m.expires_at, m.created_at))))) ) in let decode (id, (value, (data, (kind, (status, (expires_at, created_at)))))) = match Status.of_string status with | Ok status -> Ok { id; value; data; kind; status; expires_at; created_at } | Error msg -> Error msg in Caqti_type.( custom ~encode ~decode (tup2 Data.Id.t_string (tup2 string (tup2 (option string) (tup2 string (tup2 string (tup2 ptime ptime)))))))
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>