Add rpc disconnect
This commit is contained in:
parent
1bc08295ef
commit
d892caa288
@ -12,7 +12,10 @@ from chainlib.eth.sign import (
|
|||||||
sign_message,
|
sign_message,
|
||||||
)
|
)
|
||||||
from chainlib.eth.address import to_checksum_address
|
from chainlib.eth.address import to_checksum_address
|
||||||
from chainlib.eth.tx import TxFormat
|
from chainlib.eth.tx import (
|
||||||
|
TxFormat,
|
||||||
|
unpack,
|
||||||
|
)
|
||||||
from chainlib.chain import ChainSpec
|
from chainlib.chain import ChainSpec
|
||||||
from eth_accounts_index import AccountRegistry
|
from eth_accounts_index import AccountRegistry
|
||||||
|
|
||||||
@ -48,46 +51,6 @@ from cic_eth.queue.tx import (
|
|||||||
|
|
||||||
logg = logging.getLogger()
|
logg = logging.getLogger()
|
||||||
celery_app = celery.current_app
|
celery_app = celery.current_app
|
||||||
|
|
||||||
|
|
||||||
def unpack_register(data):
|
|
||||||
"""Verifies that a transaction is an "AccountRegister.add" transaction, and extracts call parameters from it.
|
|
||||||
|
|
||||||
:param data: Raw input data from Ethereum transaction.
|
|
||||||
:type data: str, 0x-hex
|
|
||||||
:raises ValueError: Function signature does not match AccountRegister.add
|
|
||||||
:returns: Parsed parameters
|
|
||||||
:rtype: dict
|
|
||||||
"""
|
|
||||||
data = strip_0x(data)
|
|
||||||
f = data[:8]
|
|
||||||
if f != '0a3b0a4f':
|
|
||||||
raise ValueError('Invalid account index register data ({})'.format(f))
|
|
||||||
|
|
||||||
d = data[8:]
|
|
||||||
return {
|
|
||||||
'to': to_checksum_address(d[64-40:64]),
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
def unpack_gift(data):
|
|
||||||
"""Verifies that a transaction is a "Faucet.giveTo" transaction, and extracts call parameters from it.
|
|
||||||
|
|
||||||
:param data: Raw input data from Ethereum transaction.
|
|
||||||
:type data: str, 0x-hex
|
|
||||||
:raises ValueError: Function signature does not match AccountRegister.add
|
|
||||||
:returns: Parsed parameters
|
|
||||||
:rtype: dict
|
|
||||||
"""
|
|
||||||
data = strip_0x(data)
|
|
||||||
f = data[:8]
|
|
||||||
if f != '63e4bff4':
|
|
||||||
raise ValueError('Invalid gift data ({})'.format(f))
|
|
||||||
|
|
||||||
d = data[8:]
|
|
||||||
return {
|
|
||||||
'to': to_checksum_address(d[64-40:64]),
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
# TODO: Separate out nonce initialization task
|
# TODO: Separate out nonce initialization task
|
||||||
@ -109,6 +72,7 @@ def create(self, password, chain_spec_dict):
|
|||||||
conn = RPCConnection.connect(chain_spec, 'signer')
|
conn = RPCConnection.connect(chain_spec, 'signer')
|
||||||
o = new_account()
|
o = new_account()
|
||||||
a = conn.do(o)
|
a = conn.do(o)
|
||||||
|
conn.disconnect()
|
||||||
|
|
||||||
if a == None:
|
if a == None:
|
||||||
raise SignerError('create account')
|
raise SignerError('create account')
|
||||||
@ -151,9 +115,9 @@ def register(self, account_address, chain_spec_dict, writer_address=None):
|
|||||||
|
|
||||||
# Retrieve account index address
|
# Retrieve account index address
|
||||||
rpc = RPCConnection.connect(chain_spec, 'default')
|
rpc = RPCConnection.connect(chain_spec, 'default')
|
||||||
reg = CICRegistry(chain_spec, rpc)
|
registry = CICRegistry(chain_spec, rpc)
|
||||||
call_address = AccountRole.get_address('DEFAULT', session=session)
|
call_address = AccountRole.get_address('DEFAULT', session=session)
|
||||||
account_registry_address = reg.by_name('AccountRegistry', sender_address=call_address)
|
account_registry_address = registry.by_name('AccountRegistry', sender_address=call_address)
|
||||||
|
|
||||||
# Generate and sign transaction
|
# Generate and sign transaction
|
||||||
rpc_signer = RPCConnection.connect(chain_spec, 'signer')
|
rpc_signer = RPCConnection.connect(chain_spec, 'signer')
|
||||||
@ -162,6 +126,8 @@ def register(self, account_address, chain_spec_dict, writer_address=None):
|
|||||||
gas_oracle = self.create_gas_oracle(rpc, AccountRegistry.gas)
|
gas_oracle = self.create_gas_oracle(rpc, AccountRegistry.gas)
|
||||||
account_registry = AccountRegistry(signer=rpc_signer, nonce_oracle=nonce_oracle, gas_oracle=gas_oracle, chain_id=chain_spec.chain_id())
|
account_registry = AccountRegistry(signer=rpc_signer, nonce_oracle=nonce_oracle, gas_oracle=gas_oracle, chain_id=chain_spec.chain_id())
|
||||||
(tx_hash_hex, tx_signed_raw_hex) = account_registry.add(account_registry_address, writer_address, account_address, tx_format=TxFormat.RLP_SIGNED)
|
(tx_hash_hex, tx_signed_raw_hex) = account_registry.add(account_registry_address, writer_address, account_address, tx_format=TxFormat.RLP_SIGNED)
|
||||||
|
rpc_signer.disconnect()
|
||||||
|
|
||||||
# TODO: if cache task fails, task chain will not return
|
# TODO: if cache task fails, task chain will not return
|
||||||
cache_task = 'cic_eth.eth.account.cache_account_data'
|
cache_task = 'cic_eth.eth.account.cache_account_data'
|
||||||
|
|
||||||
@ -175,6 +141,7 @@ def register(self, account_address, chain_spec_dict, writer_address=None):
|
|||||||
gas_pair = gas_oracle.get_gas(tx_signed_raw_hex)
|
gas_pair = gas_oracle.get_gas(tx_signed_raw_hex)
|
||||||
gas_budget = gas_pair[0] * gas_pair[1]
|
gas_budget = gas_pair[0] * gas_pair[1]
|
||||||
logg.debug('register user tx {} {} {}'.format(tx_hash_hex, queue, gas_budget))
|
logg.debug('register user tx {} {} {}'.format(tx_hash_hex, queue, gas_budget))
|
||||||
|
rpc.disconnect()
|
||||||
|
|
||||||
s = create_check_gas_task(
|
s = create_check_gas_task(
|
||||||
[tx_signed_raw_hex],
|
[tx_signed_raw_hex],
|
||||||
@ -246,10 +213,17 @@ def have(self, account, chain_str):
|
|||||||
o = sign_message(account, '0x2a')
|
o = sign_message(account, '0x2a')
|
||||||
try:
|
try:
|
||||||
conn = RPCConnection.connect(chain_spec, 'signer')
|
conn = RPCConnection.connect(chain_spec, 'signer')
|
||||||
|
except Exception as e:
|
||||||
|
logg.debug('cannot sign with {}: {}'.format(account, e))
|
||||||
|
return None
|
||||||
|
|
||||||
|
try:
|
||||||
conn.do(o)
|
conn.do(o)
|
||||||
|
conn.disconnect()
|
||||||
return account
|
return account
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logg.debug('cannot sign with {}: {}'.format(account, e))
|
logg.debug('cannot sign with {}: {}'.format(account, e))
|
||||||
|
conn.disconnect()
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
@ -292,7 +266,7 @@ def cache_gift_data(
|
|||||||
c = RpcClient(chain_spec)
|
c = RpcClient(chain_spec)
|
||||||
|
|
||||||
tx_signed_raw_bytes = bytes.fromhex(tx_signed_raw_hex[2:])
|
tx_signed_raw_bytes = bytes.fromhex(tx_signed_raw_hex[2:])
|
||||||
tx = unpack_signed_raw_tx(tx_signed_raw_bytes, chain_spec.chain_id())
|
tx = unpack(tx_signed_raw_bytes, chain_spec.chain_id())
|
||||||
tx_data = unpack_gift(tx['data'])
|
tx_data = unpack_gift(tx['data'])
|
||||||
|
|
||||||
#session = SessionBase.create_session()
|
#session = SessionBase.create_session()
|
||||||
@ -321,7 +295,7 @@ def cache_account_data(
|
|||||||
self,
|
self,
|
||||||
tx_hash_hex,
|
tx_hash_hex,
|
||||||
tx_signed_raw_hex,
|
tx_signed_raw_hex,
|
||||||
chain_spec,
|
chain_spec_dict,
|
||||||
):
|
):
|
||||||
"""Generates and commits transaction cache metadata for an AccountsIndex.add transaction
|
"""Generates and commits transaction cache metadata for an AccountsIndex.add transaction
|
||||||
|
|
||||||
@ -334,13 +308,10 @@ def cache_account_data(
|
|||||||
:returns: Transaction hash and id of cache element in storage backend, respectively
|
:returns: Transaction hash and id of cache element in storage backend, respectively
|
||||||
:rtype: tuple
|
:rtype: tuple
|
||||||
"""
|
"""
|
||||||
|
chain_spec = ChainSpec.from_dict(chain_spec_dict)
|
||||||
#c = RpcClient(chain_spec)
|
|
||||||
return
|
|
||||||
|
|
||||||
tx_signed_raw_bytes = bytes.fromhex(tx_signed_raw_hex[2:])
|
tx_signed_raw_bytes = bytes.fromhex(tx_signed_raw_hex[2:])
|
||||||
#tx = unpack_signed_raw_tx(tx_signed_raw_bytes, chain_spec.chain_id())
|
|
||||||
tx = unpack(tx_signed_raw_bytes, chain_id=chain_spec.chain_id())
|
tx = unpack(tx_signed_raw_bytes, chain_id=chain_spec.chain_id())
|
||||||
|
raise NotImplementedError('unpack register must be replaced with AccountRegistry parser')
|
||||||
tx_data = unpack_register(tx['data'])
|
tx_data = unpack_register(tx['data'])
|
||||||
|
|
||||||
session = SessionBase.create_session()
|
session = SessionBase.create_session()
|
||||||
|
@ -66,6 +66,7 @@ def balance(tokens, holder_address, chain_spec_dict):
|
|||||||
o = c.balance_of(address, holder_address, sender_address=caller_address)
|
o = c.balance_of(address, holder_address, sender_address=caller_address)
|
||||||
r = rpc.do(o)
|
r = rpc.do(o)
|
||||||
t['balance_network'] = c.parse_balance(r)
|
t['balance_network'] = c.parse_balance(r)
|
||||||
|
rpc.disconnect()
|
||||||
|
|
||||||
return tokens
|
return tokens
|
||||||
|
|
||||||
@ -107,6 +108,10 @@ def transfer(self, tokens, holder_address, receiver_address, value, chain_spec_d
|
|||||||
gas_oracle = self.create_gas_oracle(rpc, MaxGasOracle.gas)
|
gas_oracle = self.create_gas_oracle(rpc, MaxGasOracle.gas)
|
||||||
c = ERC20(signer=rpc_signer, gas_oracle=gas_oracle, nonce_oracle=nonce_oracle, chain_id=chain_spec.chain_id())
|
c = ERC20(signer=rpc_signer, gas_oracle=gas_oracle, nonce_oracle=nonce_oracle, chain_id=chain_spec.chain_id())
|
||||||
(tx_hash_hex, tx_signed_raw_hex) = c.transfer(t['address'], holder_address, receiver_address, value, tx_format=TxFormat.RLP_SIGNED)
|
(tx_hash_hex, tx_signed_raw_hex) = c.transfer(t['address'], holder_address, receiver_address, value, tx_format=TxFormat.RLP_SIGNED)
|
||||||
|
|
||||||
|
rpc_signer.disconnect()
|
||||||
|
rpc.disconnect()
|
||||||
|
|
||||||
cache_task = 'cic_eth.eth.erc20.cache_transfer_data'
|
cache_task = 'cic_eth.eth.erc20.cache_transfer_data'
|
||||||
|
|
||||||
register_tx(tx_hash_hex, tx_signed_raw_hex, chain_spec, queue, cache_task=cache_task, session=session)
|
register_tx(tx_hash_hex, tx_signed_raw_hex, chain_spec, queue, cache_task=cache_task, session=session)
|
||||||
@ -166,6 +171,10 @@ def approve(self, tokens, holder_address, spender_address, value, chain_spec_dic
|
|||||||
gas_oracle = self.create_gas_oracle(rpc, MaxGasOracle.gas)
|
gas_oracle = self.create_gas_oracle(rpc, MaxGasOracle.gas)
|
||||||
c = ERC20(signer=rpc_signer, gas_oracle=gas_oracle, nonce_oracle=nonce_oracle, chain_id=chain_spec.chain_id())
|
c = ERC20(signer=rpc_signer, gas_oracle=gas_oracle, nonce_oracle=nonce_oracle, chain_id=chain_spec.chain_id())
|
||||||
(tx_hash_hex, tx_signed_raw_hex) = c.approve(t['address'], holder_address, spender_address, value, tx_format=TxFormat.RLP_SIGNED)
|
(tx_hash_hex, tx_signed_raw_hex) = c.approve(t['address'], holder_address, spender_address, value, tx_format=TxFormat.RLP_SIGNED)
|
||||||
|
|
||||||
|
rpc_signer.disconnect()
|
||||||
|
rpc.disconnect()
|
||||||
|
|
||||||
cache_task = 'cic_eth.eth.erc20.cache_approve_data'
|
cache_task = 'cic_eth.eth.erc20.cache_approve_data'
|
||||||
|
|
||||||
register_tx(tx_hash_hex, tx_signed_raw_hex, chain_spec, queue, cache_task=cache_task, session=session)
|
register_tx(tx_hash_hex, tx_signed_raw_hex, chain_spec, queue, cache_task=cache_task, session=session)
|
||||||
@ -213,6 +222,7 @@ def resolve_tokens_by_symbol(self, token_symbols, chain_spec_dict):
|
|||||||
'address': token_address,
|
'address': token_address,
|
||||||
'converters': [],
|
'converters': [],
|
||||||
})
|
})
|
||||||
|
rpc.disconnect()
|
||||||
return tokens
|
return tokens
|
||||||
|
|
||||||
|
|
||||||
|
@ -124,8 +124,10 @@ def check_gas(self, tx_hashes, chain_spec_dict, txs=[], address=None, gas_requir
|
|||||||
try:
|
try:
|
||||||
o = balance(address)
|
o = balance(address)
|
||||||
r = conn.do(o)
|
r = conn.do(o)
|
||||||
|
conn.disconnect()
|
||||||
gas_balance = abi_decode_single(ABIContractType.UINT256, r)
|
gas_balance = abi_decode_single(ABIContractType.UINT256, r)
|
||||||
except EthException as e:
|
except EthException as e:
|
||||||
|
conn.disconnect()
|
||||||
raise EthError('gas_balance call for {}: {}'.format(address, e))
|
raise EthError('gas_balance call for {}: {}'.format(address, e))
|
||||||
|
|
||||||
logg.debug('address {} has gas {} needs {}'.format(address, gas_balance, gas_required))
|
logg.debug('address {} has gas {} needs {}'.format(address, gas_balance, gas_required))
|
||||||
|
@ -49,7 +49,7 @@ def custodial_roles(
|
|||||||
for k in r.keys():
|
for k in r.keys():
|
||||||
role = AccountRole.set(k, r[k])
|
role = AccountRole.set(k, r[k])
|
||||||
init_database.add(role)
|
init_database.add(role)
|
||||||
logg.error('adding role {} -> {}'.format(k, r[k]))
|
logg.info('adding role {} -> {}'.format(k, r[k]))
|
||||||
init_database.commit()
|
init_database.commit()
|
||||||
return r
|
return r
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user