An LFE riak & riak cs client wrapper
Mostly because the module names of the Erlang Riak client are a bit cumbersome. And not Lispy.
You will need protoc
in your $PATH
. Installing Protocol Buffers will
do the trick.
Just add it to your rebar.config
deps:
{deps, [
...
{lric, ".*",
{git, "git@github.com:billosys/lric.git", "master"}}
]}.
And then do:
$ make compile
Below is a quick sample from the Riak docs converted to LFE and lric. First, let's start up the LFE REPL:
$ make repl-no-deps
...
LFE Shell V6.2 (abort with ^G)
>
Then let's connect to the Riak server and define some variables:
> (set `#(ok ,pid) (lric:start-link "127.0.0.1" 8087))
#(ok <0.32.0>)
> (set my-bucket (binary "test"))
#B(116 101 115 116)
> (set key (binary "key"))
#B(107 101 121)
> (set value (binary "a value"))
#B(97 32 118 97 108 117 101)
With these in place, we can create an object:
> (set obj (lrico:new my-bucket key value))
#(riakc_obj
#B(116 101 115 116)
#B(107 101 121)
undefined
()
undefined
#B(97 32 118 97 108 117 101))
>
and then store it in Riak:
> (lric:put pid obj)
ok
Now let's get it back out of Riak:
> (set `#(ok ,result) (lric:get pid my-bucket key))
#(ok
#(riakc_obj
#B(116 101 115 116)
#B(107 101 121)
#B(107 206 97 96 96 96 204 96 ...)
(#(#(dict
2
16
16
8
80
48
#(() () () () () () () () () () () () ...)
#(#(() () () () () () () () () () ...)))
#B(97 32 118 97 108 117 101)))
undefined
undefined))
That's the complete Riak object; how do we get just the value? Simply call the appropriate object function:
> (lrico:get-value result)
#B(97 32 118 97 108 117 101)
Or the more readable:
> (binary_to_list (lrico:get-value result))
"a value"
For more usage examples, see the following docs (all of which are being ported by Billo from the Basho originals):
- Taste of Riak
- The Little Riak Book (TBD)
- Basic Usage (TBD)
- Riak Search (TBD)
- Riak Data Types (TBD)