2019-06-30 22:04:47 -06:00
|
|
|
from eth2spec.utils.ssz.ssz_impl import hash_tree_root, serialize
|
2019-06-01 02:22:14 +02:00
|
|
|
from eth2spec.utils.ssz.ssz_typing import (
|
2019-06-30 22:04:47 -06:00
|
|
|
uint, boolean,
|
|
|
|
Bitlist, Bitvector, Container
|
2019-06-01 02:22:14 +02:00
|
|
|
)
|
2019-04-07 23:36:05 +10:00
|
|
|
|
|
|
|
|
2019-06-30 15:36:54 +02:00
|
|
|
def encode(value, include_hash_tree_roots=False):
|
2019-06-19 02:37:22 +02:00
|
|
|
if isinstance(value, uint):
|
2019-05-27 22:19:18 +02:00
|
|
|
# Larger uints are boxed and the class declares their byte length
|
2019-06-19 02:37:22 +02:00
|
|
|
if value.type().byte_len > 8:
|
2019-06-22 21:49:42 +02:00
|
|
|
return str(int(value))
|
|
|
|
return int(value)
|
2019-06-27 09:51:06 +01:00
|
|
|
elif isinstance(value, boolean):
|
2019-06-22 20:04:17 +02:00
|
|
|
return value == 1
|
2019-06-30 22:04:47 -06:00
|
|
|
elif isinstance(value, (Bitlist, Bitvector)):
|
|
|
|
return '0x' + serialize(value).hex()
|
2019-06-22 19:48:06 +02:00
|
|
|
elif isinstance(value, list): # normal python lists, ssz-List, Vector
|
2019-06-19 02:37:22 +02:00
|
|
|
return [encode(element, include_hash_tree_roots) for element in value]
|
2019-06-22 19:48:06 +02:00
|
|
|
elif isinstance(value, bytes): # both bytes and BytesN
|
2019-04-07 23:36:05 +10:00
|
|
|
return '0x' + value.hex()
|
2019-06-19 02:37:22 +02:00
|
|
|
elif isinstance(value, Container):
|
2019-04-07 23:36:05 +10:00
|
|
|
ret = {}
|
2019-06-19 02:37:22 +02:00
|
|
|
for field_value, field_name in zip(value, value.get_fields().keys()):
|
|
|
|
ret[field_name] = encode(field_value, include_hash_tree_roots)
|
2019-04-07 23:36:05 +10:00
|
|
|
if include_hash_tree_roots:
|
2019-06-19 02:37:22 +02:00
|
|
|
ret[field_name + "_hash_tree_root"] = '0x' + hash_tree_root(field_value).hex()
|
2019-04-07 23:36:05 +10:00
|
|
|
if include_hash_tree_roots:
|
2019-06-19 02:37:22 +02:00
|
|
|
ret["hash_tree_root"] = '0x' + hash_tree_root(value).hex()
|
2019-04-07 23:36:05 +10:00
|
|
|
return ret
|
|
|
|
else:
|
2019-06-19 02:37:22 +02:00
|
|
|
raise Exception(f"Type not recognized: value={value}, typ={value.type()}")
|