Run extensions processing from core processor

This commit is contained in:
nolash
2021-10-11 15:28:09 +02:00
parent dd9640b383
commit 23567905a1
13 changed files with 233 additions and 60 deletions

View File

@@ -27,7 +27,7 @@ logg = logging.getLogger(__name__)
class CICEth:
def __init__(self, core_processor, chain_spec, resources, proof, signer=None, metadata=None, rpc=None, fee_oracle=None):
def __init__(self, chain_spec, resources, proof, signer=None, rpc=None, fee_oracle=None, outputs_writer=None):
"""resources will be modified
"""
self.resources = resources
@@ -35,14 +35,13 @@ class CICEth:
self.chain_spec = chain_spec
self.signer = signer
self.rpc = rpc
self.core_processor = core_processor
self.fee_oracle = fee_oracle
self.metadata = metadata
self.token_details = None
self.token_address = None
self.token_code = None
self.outputs = []
self.tx_format = TxFormat.RAW_ARGS
self.outputs_writer = outputs_writer
if self.rpc != None:
self.tx_format = TxFormat.JSONRPC
elif self.signer != None:
@@ -122,10 +121,20 @@ class CICEth:
return (args, args_types, positions)
def add_outputs(self, k, v):
logg.debug('adding outputs {} {}'.format(k, v))
self.outputs.append((k, v))
def get_outputs(self):
return self.outputs
def process_token(self, writer=None):
if writer == None:
writer = self.core_processor.writer()
writer = self.outputs_writer
logg.debug('ZZZZZZZZ token details {}'.format(self.token_details))
(args, args_types, positions) = self.__order_args()
enc = ABIContractEncoder()
@@ -158,13 +167,13 @@ class CICEth:
if r == None:
r = code
self.outputs.append(r)
self.add_outputs('token', r)
return r
def process_token_index(self, writer=None):
if writer == None:
writer = self.core_processor.writer()
writer = self.outputs_writer
signer_address = self.resources['token_index']['key_address']
contract_address = self.resources['token_index']['reference']
@@ -184,13 +193,13 @@ class CICEth:
else:
r = o
self.outputs.append(r)
self.add_outputs('token_index', r)
return r
def process_address_declarator(self, writer=None):
if writer == None:
writer = self.core_processor.writer()
writer = self.outputs_writer
signer_address = self.resources['address_declarator']['key_address']
contract_address = self.resources['address_declarator']['reference']
@@ -201,21 +210,26 @@ class CICEth:
nonce_oracle = RPCNonceOracle(signer_address, conn=self.rpc)
c = Declarator(self.chain_spec, signer=self.signer, nonce_oracle=nonce_oracle, gas_oracle=gas_oracle)
r = []
results = []
for proof in self.proof.get():
o = c.add_declaration(contract_address, signer_address, self.token_address, proof, tx_format=self.tx_format)
r = None
if self.rpc != None:
r.append(self.rpc.do(o[1]))
r = self.rpc.do(o[1])
elif self.signer != None:
r.append(o[1])
r = o[1]
else:
r.append(o)
r = o
self.add_outputs('address_declarator', r)
results.append(r)
self.outputs += r
return r
return results
def process(self):
def process(self, writer=None):
if writer == None:
writer = self.outputs_writer
tasks = []
self.token_address = self.resources['token']['reference']
@@ -230,12 +244,10 @@ class CICEth:
for task in tasks:
logg.debug('ciceth adapter process {}'.format(task))
r = getattr(self, 'process_' + task)(writer=self.core_processor.writer())
r = getattr(self, 'process_' + task)(writer=writer)
self.core_processor.process()
return self.outputs
return self.token_address
def new(core_processor, resources, proof, signer_hint=None):
return CICEth(core_processor, resources, proof, signer=None)
def new(resources, proof, signer_hint=None):
return CICEth(resources, proof, signer=None)