nbson
is an OTP library to encode/decode BSON documents from/to Erlang terms.
%%% e.g., rebar.config
{deps, [
{nbson, {git, "[email protected]:nomasystems/nbson.git", {branch, "main"}}}
]}.
nbson
exposes utilities via its API that allows you to:
Function | Description |
---|---|
nbson:encode/1 |
Serialize an Erlang term to BSON |
nbson:decode/2 |
Deserialize a BSON to an Erlang term |
nbson
represents BSONs as Erlang proplists with tuple values only.
Produced proplists' keys are binaries and value types depend on the associated BSON type.
The following table represents the association between Erlang types and BSON types on serialization.
Erlang Data Type | BSON Types |
---|---|
float() |
Double (1) |
binary() |
String (2) |
[ tuple() | _ ] |
Object (3) |
list() |
Array (4) |
{data, binary, binary()} |
Binary data (5) |
undefined |
Undefined (6) |
{object_id, <<_:96>>} |
ObjectId (7) |
false | true |
Boolean (8) |
{integer(), integer(), integer()} |
Date (9) |
null |
Null (10) |
{regex, charlist(), charlist()} |
Regular Expression (11) |
{pointer, binary(), <<_:96>>} |
DBPointer (12) |
{javascript, [{}], binary()} |
JavaScript (13) |
Atom :: atom() when Atom =/= min_key, Atom =/= max_key |
Symbol (14) |
{javascript, [ tuple() | _ ], binary()} |
JavaScript code with scope (15) |
I32 :: integer() when -16#80000000 =< I32, I32 =< 16#7fffffff |
32-bit integer (16) |
{timestamp, binary(), binary()} |
Timestamp (17) |
I64 :: integer() when -16#8000000000000000 =< I64, I64 =< 16#7fffffffffffffff |
64-bit integer (18) |
{long, I64 :: integer()} when -16#8000000000000000 =< I64, I64 =< 16#7fffffffffffffff |
64-bit integer (18) |
max_key |
Max key (127) |
min_key |
Min key (-1) |
On deserialization, we prevent the dynamic generation of atoms by converting BSON Symbol, Max Key and Min Key values to Erlang binaries.
The BSON decoder implementation in nbson_decoder.erl
uses CPS. In this particular case, CPS leads to the use of the sub binary delayed optimization and improved efficiency in the deserialization process.
The nbson_bench repository hosts benchmarks to measure the decoding and encoding times of different BSONs compared to other equivalent tools.
Check out the nbson_SUITE.erl
file under tests
to see some examples of BSONs and their Erlang representation.
Any doubt or suggestion? Please check out our issue tracker.