A Clojure library designed to provide more abstractions and means to communicate with Clojure's core.async channels and avoid constantly rewriting boilerplate channels handling functions, such as producing and consuming at the beginnings and ends of pipelines.
Add the following dependency in your leiningen project:
[bsless/more.async "0.0.2-alpha"]
(require '[clojure.core.async :as a]
'[clojure.more.async :as ma])
For example, with kinsky's kafka client:
(require '[kinsky.client :as client])
(defn make-consumer
[]
(let [c (client/consumer {:bootstrap.servers "localhost:9092"
:group.id "mygroup"}
(client/keyword-deserializer)
(client/edn-deserializer))]
(client/subscribe! c "account")
c))
(def msg-ch (a/chan))
(ma/produce-bound-blocking
msg-ch
#(client/poll! % 100)
make-consumer
client/close!)
(def out-ch (a/chan))
(let [p (client/producer {:bootstrap.servers "localhost:9092"}
(client/keyword-serializer)
(client/edn-serializer))
topic "account"]
(ma/consume out-ch #(client/send! p topic %)))
Copyright © 2019 Ben Sless
This program and the accompanying materials are made available under the terms of the Eclipse Public License 2.0 which is available at http://www.eclipse.org/legal/epl-2.0.
This Source Code may also be made available under the following Secondary Licenses when the conditions for such availability set forth in the Eclipse Public License, v. 2.0 are satisfied: GNU General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version, with the GNU Classpath Exception which is available at https://www.gnu.org/software/classpath/license.html.
Can you improve this documentation?Edit on GitHub
cljdoc is a website building & hosting documentation for Clojure/Script libraries
× close