Add proof processing
This commit is contained in:
parent
8451285d0d
commit
09fa8f2a4c
@ -55,6 +55,7 @@ class Attachment(Data):
|
||||
logg.debug('writing {}'.format(k))
|
||||
writer.write(k, v)
|
||||
|
||||
|
||||
def __str__(self):
|
||||
s = ''
|
||||
for i in range(len(self.contents)):
|
||||
|
@ -210,7 +210,9 @@ class CICEth:
|
||||
c = Declarator(self.chain_spec, signer=self.signer, nonce_oracle=nonce_oracle, gas_oracle=gas_oracle)
|
||||
|
||||
results = []
|
||||
for proof in self.proof.get():
|
||||
(main_proof, all_proofs) = self.proof.get()
|
||||
for proof in all_proofs:
|
||||
logg.debug('proof {} '.format(proof))
|
||||
k = 'address_declarator_' + proof
|
||||
o = c.add_declaration(contract_address, signer_address, self.token_address, proof, tx_format=self.tx_format)
|
||||
r = None
|
||||
|
22
cic/proof.py
22
cic/proof.py
@ -81,6 +81,7 @@ class Proof(Data):
|
||||
|
||||
hsh = self.hash(b).hex()
|
||||
self.attachments[hsh] = self.temp_proof_path
|
||||
logg.debug('cbor of {} is {} hashes to {}'.format(v, b.hex(), hsh))
|
||||
|
||||
if self.extra_attachments != None:
|
||||
a = self.extra_attachments.asdict()
|
||||
@ -89,7 +90,26 @@ class Proof(Data):
|
||||
|
||||
hshs = self.__get_ordered_hashes()
|
||||
|
||||
return hshs
|
||||
return (hsh, hshs)
|
||||
|
||||
|
||||
def process(self, token_address=None, writer=None):
|
||||
if writer == None:
|
||||
writer = self.writer
|
||||
|
||||
(hsh, hshs) = self.get()
|
||||
hshs = list(map(strip_0x, hshs))
|
||||
hshs_bin = list(map(bytes.fromhex, hshs))
|
||||
hshs_cat = b''.join(hshs_bin)
|
||||
|
||||
r = self.hash(hshs_cat)
|
||||
r_hex = r.hex()
|
||||
|
||||
logg.debug('generated proof {} for hashes {}'.format(r_hex, hshs))
|
||||
|
||||
writer.write(r_hex, hshs_cat)
|
||||
|
||||
return r_hex
|
||||
|
||||
|
||||
def __str__(self):
|
||||
|
@ -2,3 +2,4 @@ eth-erc20>=0.1.2a3,<0.2.0
|
||||
eth_tester==0.5.0b3
|
||||
py-evm==0.3.0a20
|
||||
rlp==2.0.1
|
||||
chainlib-eth>=0.0.10a2,<0.1.0
|
||||
|
@ -25,7 +25,6 @@ class TestCICBase(unittest.TestCase):
|
||||
def setUp(self):
|
||||
super(TestCICBase, self).setUp()
|
||||
random.seed(42)
|
||||
self.initial_description = add_0x(random.randbytes(32).hex())
|
||||
|
||||
addresses = [
|
||||
add_0x(random.randbytes(20).hex()),
|
||||
|
@ -8,32 +8,40 @@ from cic import Proof
|
||||
from cic.attachment import Attachment
|
||||
|
||||
# test imports
|
||||
from tests.base_cic import test_data_dir
|
||||
from tests.base_cic import (
|
||||
test_data_dir,
|
||||
TestCICBase,
|
||||
)
|
||||
|
||||
logging.basicConfig(level=logging.DEBUG)
|
||||
logg = logging.getLogger()
|
||||
|
||||
|
||||
proof_hash = '0f6fc017f29caf512c0feaaf83bc10614b488311cace2973dc248dc24b01e04f'
|
||||
foo_hash = '2c26b46b68ffc68ff99b453c1d30413413422d706483bfa0f98a5e886266e7ae'
|
||||
bar_hash = 'fcde2b2edba56bf408601fb721fe9b5c338d10ee429ea04fae5511b68fbf8fb9'
|
||||
root_merged_hash = '1b38b0e9a2cc0895c72e5f460a613bb0f3d88c4a87c1ee2b39a41c64f1dbcd1e'
|
||||
root_unmerged_hash = '86d0091b98635a45da472388a1204104d7d10ea1199c1bd9c1d235de73a2c285'
|
||||
|
||||
class TestProof(unittest.TestCase):
|
||||
class TestProof(TestCICBase):
|
||||
|
||||
def test_proof_serialize(self):
|
||||
proof_path = os.path.join(test_data_dir, 'proof')
|
||||
c = Proof(path=proof_path)
|
||||
v = c.get()
|
||||
logg.debug('v {}'.format(v))
|
||||
c = Proof(path=proof_path, writer=self.outputs_writer)
|
||||
c.load()
|
||||
v = c.process()
|
||||
self.assertEqual(v, root_unmerged_hash)
|
||||
|
||||
|
||||
def test_proof_serialize_merge(self):
|
||||
proof_path = os.path.join(test_data_dir, 'proof')
|
||||
|
||||
attach = Attachment(proof_path)
|
||||
attach = Attachment(proof_path, writer=self.outputs_writer)
|
||||
attach.load()
|
||||
|
||||
c = Proof(path=proof_path, attachments=attach)
|
||||
v = c.get()
|
||||
c = Proof(path=proof_path, attachments=attach, writer=self.outputs_writer)
|
||||
c.load()
|
||||
v = c.process()
|
||||
self.assertEqual(v, root_merged_hash)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
Loading…
Reference in New Issue
Block a user