Skip to content

Latest commit

 

History

History
50 lines (31 loc) · 1.83 KB

README.md

File metadata and controls

50 lines (31 loc) · 1.83 KB

konserve-carmine

A redis backend for konserve implemented with carmine.

Status

Clojure CI codecov

Usage

Clojars Project

[io.replikativ/konserve-carmine "0.1.4-SNAPSHOT"]

The purpose of konserve is to have a unified associative key-value interface for edn datastructures and binary blobs. Use the standard interface functions of konserve.

You can provide the carmine redis connection specification map to the new-carmine-store constructor as an argument. We do not require additional settings beyond the konserve serialization protocol for the store, so you can still access the store through carmine directly wherever you need.

(require '[konserve-carmine.core :refer :all]
         '[clojure.core.async :refer [<!!] :as async]
         '[konserve.core :as k])
  
  (def carmine-store (<!! (new-carmine-store {:pool {} :spec {:uri "redis://localhost:6379/"}})))

  (<!! (k/exists? carmine-store  "cecilia"))
  (<!! (k/get-in carmine-store ["cecilia"]))
  (<!! (k/assoc-in carmine-store ["cecilia"] 28))
  (<!! (k/update-in carmine-store ["cecilia"] inc))
  (<!! (k/get-in carmine-store ["cecilia"]))

  (defrecord Test [a])
  (<!! (k/assoc-in carmine-store ["agatha"] (Test. 35)))
  (<!! (k/get-in carmine-store ["agatha"]))

License

Copyright © 2016-2020 Christian Weilbach and contributors

Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.