bson_as_json_with_opts()#
Synopsis#
char *
bson_as_json_with_opts (const bson_t *bson, size_t *length, const bson_json_opts_t *opts);
Parameters#
bson
: A bson_t.length
: An optional location for the length of the resulting string.opts
: A bson_json_opts_t.
Description#
bson_as_json_with_opts() encodes bson
as a UTF-8 string in the MongoDB Extended JSON format or libbson’s Legacy Extended JSON.
The caller is responsible for freeing the resulting UTF-8 encoded string by calling bson_free() with the result.
If non-NULL, length
will be set to the length of the result in bytes.
The opts
structure is used to pass options for the encoding process. Please refer to the documentation of bson_json_opts_t for more details.
Returns#
If successful, a newly allocated UTF-8 encoded string and length
is set.
Upon failure, NULL is returned.
Example#
bson_t *b = BCON_NEW ("foo", BCON_INT32 (123));
bson_json_opts_t *opts = bson_json_opts_new (BSON_JSON_MODE_CANONICAL, BSON_MAX_LEN_UNLIMITED);
char *str = bson_as_json_with_opts (b, NULL, opts);
printf ("Canonical Extended JSON: %s\n", str);
// Prints:
// Canonical Extended JSON: { "foo" : { "$numberInt" : "123" } }
bson_free (str);
bson_json_opts_destroy (opts);
bson_destroy (b);