Skip to main content

Python implementation of the DAG-CBOR codec.

Project description

dag-cbor: A Python implementation of DAG-CBOR

Generic badge PyPI version shields.io PyPI status Checked with Mypy Python package

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 integers
  • float for uniformly distributed floats, with fixed decimals
  • bytes for byte-strings of uniformly distributed length, with uniformly distributed bytes
  • str for strings of uniformly distributed length, with uniformly distributed codepoints (all valid UTF-8 strings, by rejection sampling)
  • bool for False or True (50% each)
  • bool_none for False, True or None (33.3% each)
  • list for lists of uniformly distributed length, with random elements of any type
  • dict for dictionaries of uniformly distributed length, with distinct random string keys and random values of any type
  • cid for CID data (instance of BaseCID from the py-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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dag-cbor-0.0.5.post1.tar.gz (14.2 kB view details)

Uploaded Source

Built Distribution

dag_cbor-0.0.5.post1-py3-none-any.whl (13.1 kB view details)

Uploaded Python 3

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

Hashes for dag-cbor-0.0.5.post1.tar.gz
Algorithm Hash digest
SHA256 ea818e5955ce1d02ed3580fba132f045a720d60ad852f7355cbec94134c2cc29
MD5 209e419a0af56f99e2102bee6e430350
BLAKE2b-256 e2d29048869b1d30e39244f36364621768318199eab4f897fd326346e5cf6b7a

See more details on using hashes here.

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

Hashes for dag_cbor-0.0.5.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 f5d5fec77527858733a8a41307579756608efa2c3c366bd60d4765240a5134c0
MD5 0b6f9851856c5c47eb5e11d7dc02f286
BLAKE2b-256 43eaa616acc75c96d5e1b1afa16f9db4ae0cc11538b40271f57b2896f92a8ce7

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page