package sihl
The modular functional web framework
Install
Dune Dependency
Authors
Maintainers
Sources
sihl-0.1.2.tbz
sha256=69705a3a35f204acfdda62f61056e3f0ec3ef5bcd1df1508be65b066a0b1df9c
sha512=1987d211f56d0261eefbae978065a4e6781d60ad94b08597875307e5cf6e5a1b79787d9c79f784f5a9f77c35203cfd0b488841a07adfd87b0710d6fd65422b94
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)"
>