Python implementation of the DAG-CBOR codec.
Project description
dag-cbor
: A Python implementation of DAG-CBOR
This is a fully compliant Python implementation of the DAG-CBOR codec, a subset of the Concise Binary Object Representation (CBOR) supporting the IPLD Data Model and enforcing a unique (strict) encoded representation of items.
You can install this package with pip
:
pip install dag-cbor
The documentation for this package is automatically generated by pdoc.
Basic usage
The core functionality of the library is performed by the encode
and decode
functions:
>>> import dag_cbor
>>> dag_cbor.encode({'a': 12, 'b': 'hello!'})
b'\xa2aa\x0cabfhello!'
>>> dag_cbor.decode(b'\xa2aa\x0cabfhello!')
{'a': 12, 'b': 'hello!'}
Usage with binary streams
A buffered binary stream (i.e. an instance of io.BufferedIOBase
) can be passed to the encode
function using the optional keyword argument stream
, in which case the encoded bytes are written to the stream rather than returned:
>>> from io import BytesIO
>>> mystream = BytesIO()
>>> dag_cbor.encode({'a': 12, 'b': 'hello!'}, stream=mystream)
>>> mystream.getvalue()
b'\xa2aa\x0cabfhello!'
A buffered binary stream can be passed to the decode function instead of a bytes
object, in which case the contents of the stream are read in their entirety and decoded:
>>> mystream = BytesIO(b'\xa2aa\x0cabfhello!')
>>> dag_cbor.decode(mystream)
{'a': 12, 'b': 'hello!'}
Random data
The random
module contains functions to generate random data compatible with DAG-CBOR encoding. The functions are named rand_X
, where X
is one of:
int
for uniformly distributed integersfloat
for uniformly distributed floats, with fixed decimalsbytes
for byte-strings of uniformly distributed length, with uniformly distributed bytesstr
for strings of uniformly distributed length, with uniformly distributed codepoints (all valid UTF-8 strings, by rejection sampling)bool
forFalse
orTrue
(50% each)bool_none
forFalse
,True
orNone
(33.3% each)list
for lists of uniformly distributed length, with random elements of any typedict
for dictionaries of uniformly distributed length, with distinct random string keys and random values of any typecid
for CID data (instance ofBaseCID
from thepy-cid
package)
The function call rand_X(n)
returns an iterator yielding a stream of n
random values of type X
:
>>> import pprint
>>> import dag_cbor
>>> options = dict(min_codepoint=0x41, max_codepoint=0x5a, include_cid=False)
>>> with dag_cbor.random.rand_options(**options):
... for d in dag_cbor.random.rand_dict(3):
... pprint.pp(d)
...
{'BIQPMZ': b'\x85\x1f\x07/\xcc\x00\xfc\xaa',
'EJEYDTZI': {},
'PLSG': {'G': 'JFG',
'HZE': -61.278,
'JWDRKRGZ': b'-',
'OCCKQPDJ': True,
'SJOCTZMK': False},
'PRDLN': 39.129,
'TUGRP': None,
'WZTEJDXC': -69.933}
{'GHAXI': 39.12,
'PVUWZLC': 4.523,
'TDPSU': 'TVCADUGT',
'ZHGVSNSI': [-57, 9, -78.312]}
{'': 11, 'B': True, 'FWD': {}, 'GXZBVAR': 'BTDWMGI', 'TDICHC': 87}
The function call rand_X()
, without the positional argument n
, would instead yield an infinite stream of random values. The rand_options(**options)
context manager is used to set options temporarily: in the example above, we set string characters to be uppercase alphabetic (codepoints 0x41
-0x5a
) and we excluded CID values from being generated. For the full list of functions and options, please refer to the dag_cbor.random
documentation.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file dag-cbor-0.0.5.post1.tar.gz
.
File metadata
- Download URL: dag-cbor-0.0.5.post1.tar.gz
- Upload date:
- Size: 14.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ea818e5955ce1d02ed3580fba132f045a720d60ad852f7355cbec94134c2cc29 |
|
MD5 | 209e419a0af56f99e2102bee6e430350 |
|
BLAKE2b-256 | e2d29048869b1d30e39244f36364621768318199eab4f897fd326346e5cf6b7a |
File details
Details for the file dag_cbor-0.0.5.post1-py3-none-any.whl
.
File metadata
- Download URL: dag_cbor-0.0.5.post1-py3-none-any.whl
- Upload date:
- Size: 13.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.58.0 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f5d5fec77527858733a8a41307579756608efa2c3c366bd60d4765240a5134c0 |
|
MD5 | 0b6f9851856c5c47eb5e11d7dc02f286 |
|
BLAKE2b-256 | 43eaa616acc75c96d5e1b1afa16f9db4ae0cc11538b40271f57b2896f92a8ce7 |