package sihl-cache
Cache service implementations for Sihl
Install
Dune Dependency
Authors
Maintainers
Sources
0.4.1.tar.gz
md5=b4d86577876e268da4219d29f0f3207e
sha512=e5ad0fffa52dc7dad72b84b49d375316342704e9414afe6da7a3be96cf9595cfbb5f792e9e20a7958f3fad1708f5005964daf29dc81e80923c86750441b82567
doc/index.html
Sihl Cache
This module provides the cache service and helpers to store arbitrary values. Think of the cache service as a generic key-value store where you can choose a backend.
Currently MariaDb (Sihl_cache.MariaDb
) and PostgreSql (Sihl_cache.PostgreSql
) are supported.
Installation
Backend
First, choose a backend in service/service.ml
:
module Cache = Sihl_cache.PostgreSql
Registration
Then, register the service in run/run.ml
:
let services = [ Service.Cache.register () ]
Migrations
Run pending migrations with make sihl migrate
.
Usage
The API is documented in Sihl.Contract.Cache.Sig
.
let open Lwt.Syntax in
(* Associated user_id with a value *)
let* () = Service.Cache.set ("user_id", Some "56") in
let* user_id = Service.Cache.find "user_id" in
let () =
match user_id with
| Some user_id -> print_endline @@ "Found user " ^ user_id
| None -> print_endline "No user found"
(* Delete user_id *)
Service.Cache.set ("user_id", None)
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
On This Page