1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-09 06:50:58 +00:00

feat(cardano): add support for chunked embedded CBOR

This commit is contained in:
David Misiak 2022-06-06 14:52:23 +02:00 committed by matejcik
parent 99a7c48e64
commit f7d0507a65
3 changed files with 42 additions and 0 deletions

View File

@ -120,3 +120,20 @@ class HashBuilderDict(HashBuilderCollection, Generic[K, V]):
def _header_bytes(self) -> bytes:
return cbor.create_map_header(self.size)
class HashBuilderEmbeddedCBOR(HashBuilderCollection):
"""
Accepts data chunks and serializes them as embedded CBOR.
Note that self.remaining holds the remaining data size in bytes (not chunks).
Child HashBuilders are not allowed.
"""
def add(self, chunk: bytes) -> None:
assert self.hash_fn is not None
assert self.remaining >= len(chunk)
self.remaining -= len(chunk)
self.hash_fn.update(chunk)
def _header_bytes(self) -> bytes:
return cbor.create_embedded_cbor_bytes_header(self.size)

View File

@ -320,6 +320,14 @@ def create_map_header(size: int) -> bytes:
return _header(_CBOR_MAP, size)
def create_embedded_cbor_bytes_header(size: int) -> bytes:
"""
Bytes wrapped in Tag 24 (embedded CBOR).
https://datatracker.ietf.org/doc/html/rfc7049#section-2.4.4.1
"""
return _header(_CBOR_TAG, _CBOR_RAW_TAG) + _header(_CBOR_BYTE_STRING, size)
def precedes(prev: bytes, curr: bytes) -> bool:
"""
Returns True if `prev` is smaller than `curr` with regards to

View File

@ -8,6 +8,7 @@ from apps.common.cbor import (
Tagged,
create_array_header,
create_map_header,
create_embedded_cbor_bytes_header,
decode,
encode,
encode_chunked,
@ -48,6 +49,22 @@ class TestCardanoCbor(unittest.TestCase):
with self.assertRaises(NotImplementedError):
create_map_header(2 ** 64)
def test_create_embedded_cbor_bytes_header(self):
test_vectors = [
(0, 'd81840'),
(23, 'd81857'),
((2 ** 8) - 1, 'd81858ff'),
((2 ** 16) - 1, 'd81859ffff'),
((2 ** 32) - 1, 'd8185affffffff'),
((2 ** 64) - 1, 'd8185bffffffffffffffff'),
]
for val, header_hex in test_vectors:
header = unhexlify(header_hex)
self.assertEqual(create_embedded_cbor_bytes_header(val), header)
with self.assertRaises(NotImplementedError):
create_embedded_cbor_bytes_header(2 ** 64)
def test_cbor_encoding(self):
test_vectors = [
# unsigned integers