commit 47f59735bd64912e9ed677b593b8e2015d5f796b
parent dbec6596cf65a84f707c04ae970f99eedb64bd5d
Author: nolash <dev@holbrook.no>
Date: Mon, 4 Oct 2021 10:47:17 +0200
Add deploy tools for token index, account registry
Diffstat:
5 files changed, 168 insertions(+), 5 deletions(-)
diff --git a/python/eth_address_declarator/accounts_index/accounts_index.py b/python/eth_address_declarator/accounts_index/accounts_index.py
@@ -40,7 +40,7 @@ class AccountsIndexAddressDeclarator(AccountsIndex):
@staticmethod
def gas(code=None):
- return 1200000
+ return 700000
def constructor(self, sender_address, context_address, address_declarator_address):
diff --git a/python/eth_address_declarator/accounts_index/runnable/deploy.py b/python/eth_address_declarator/accounts_index/runnable/deploy.py
@@ -0,0 +1,85 @@
+"""Deploys accounts index, registering arbitrary number of writers
+
+.. moduleauthor:: Louis Holbrook <dev@holbrook.no>
+.. pgp:: 0826EDA1702D1E87C6E2875121D2E7BB88C2A746
+
+"""
+
+# standard imports
+import sys
+import os
+import json
+import argparse
+import logging
+
+# external imports
+import chainlib.eth.cli
+from chainlib.chain import ChainSpec
+from chainlib.eth.connection import EthHTTPConnection
+from chainlib.eth.tx import receipt
+
+# local imports
+from eth_address_declarator.accounts_index import AccountsIndexAddressDeclarator
+
+logging.basicConfig(level=logging.WARNING)
+logg = logging.getLogger()
+
+arg_flags = chainlib.eth.cli.argflag_std_write
+argparser = chainlib.eth.cli.ArgumentParser(arg_flags)
+argparser.add_argument('--address-declarator', type=str, required=True, dest='address_declarator', help='address declarator backend address')
+argparser.add_argument('--token-address', type=str, required=True, dest='token_address', help='token address context for accounts registry')
+args = argparser.parse_args()
+
+extra_args = {
+ 'address_declarator': None,
+ 'token_address': None,
+ }
+config = chainlib.eth.cli.Config.from_args(args, arg_flags, extra_args=extra_args, default_fee_limit=AccountsIndexAddressDeclarator.gas())
+
+wallet = chainlib.eth.cli.Wallet()
+wallet.from_config(config)
+
+rpc = chainlib.eth.cli.Rpc(wallet=wallet)
+conn = rpc.connect_by_config(config)
+
+chain_spec = ChainSpec.from_chain_str(config.get('CHAIN_SPEC'))
+
+
+def main():
+ signer = rpc.get_signer()
+ signer_address = rpc.get_sender_address()
+
+ gas_oracle = rpc.get_gas_oracle()
+ nonce_oracle = rpc.get_nonce_oracle()
+
+ address_declarator = config.get('_ADDRESS_DECLARATOR')
+ if not config.true('_UNSAFE') and not is_checksum_address(address_declarator):
+ raise ValueError('address declarator {} is not a valid checksum address'.format(address_declarator))
+
+ token_address = config.get('_TOKEN_ADDRESS')
+ if not config.true('_UNSAFE') and not is_checksum_address(token_address):
+ raise ValueError('token {} is not a valid checksum address'.format(token_address))
+
+ c = AccountsIndexAddressDeclarator(chain_spec, signer=signer, gas_oracle=gas_oracle, nonce_oracle=nonce_oracle)
+
+ (tx_hash_hex, o) = c.constructor(signer_address, token_address, address_declarator)
+
+ if config.get('_RPC_SEND'):
+ conn.do(o)
+ if config.get('_WAIT'):
+ r = conn.wait(tx_hash_hex)
+ if r['status'] == 0:
+ sys.stderr.write('EVM revert while deploying contract. Wish I had more to tell you')
+ sys.exit(1)
+ # TODO: pass through translator for keys (evm tester uses underscore instead of camelcase)
+ address = r['contractAddress']
+
+ print(address)
+ else:
+ print(tx_hash_hex)
+ else:
+ print(o)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/python/eth_address_declarator/token_index/index.py b/python/eth_address_declarator/token_index/index.py
@@ -64,7 +64,7 @@ class TokenUniqueSymbolIndexAddressDeclarator(TokenUniqueSymbolIndex):
@staticmethod
def gas(code=None):
- return 1200000
+ return 2000000
def constructor(self, sender_address, address_declarator_address):
diff --git a/python/eth_address_declarator/token_index/runnable/deploy.py b/python/eth_address_declarator/token_index/runnable/deploy.py
@@ -0,0 +1,78 @@
+"""Deploys the token symbol index
+
+.. moduleauthor:: Louis Holbrook <dev@holbrook.no>
+.. pgp:: 0826EDA1702D1E87C6E2875121D2E7BB88C2A746
+
+"""
+
+# standard imports
+import sys
+import os
+import json
+import argparse
+import logging
+
+# external imports
+import chainlib.eth.cli
+from chainlib.chain import ChainSpec
+from chainlib.eth.tx import receipt
+
+# local imports
+from eth_address_declarator.token_index.index import TokenUniqueSymbolIndexAddressDeclarator
+
+logging.basicConfig(level=logging.WARNING)
+logg = logging.getLogger()
+
+arg_flags = chainlib.eth.cli.argflag_std_write
+argparser = chainlib.eth.cli.ArgumentParser(arg_flags)
+argparser.add_argument('--address-declarator', type=str, required=True, dest='address_declarator', help='address declarator backend address')
+args = argparser.parse_args()
+
+extra_args = {
+ 'address_declarator': None,
+ }
+
+config = chainlib.eth.cli.Config.from_args(args, arg_flags, extra_args=extra_args, default_fee_limit=TokenUniqueSymbolIndexAddressDeclarator.gas())
+
+wallet = chainlib.eth.cli.Wallet()
+wallet.from_config(config)
+
+rpc = chainlib.eth.cli.Rpc(wallet=wallet)
+conn = rpc.connect_by_config(config)
+
+chain_spec = ChainSpec.from_chain_str(config.get('CHAIN_SPEC'))
+
+
+def main():
+ signer = rpc.get_signer()
+ signer_address = rpc.get_sender_address()
+
+ gas_oracle = rpc.get_gas_oracle()
+ nonce_oracle = rpc.get_nonce_oracle()
+
+ address_declarator = config.get('_ADDRESS_DECLARATOR')
+ if not config.true('_UNSAFE') and not is_checksum_address(address_declarator):
+ raise ValueError('address declarator {} is not a valid checksum address'.format(address_declarator))
+
+ c = TokenUniqueSymbolIndexAddressDeclarator(chain_spec, signer=signer, gas_oracle=gas_oracle, nonce_oracle=nonce_oracle)
+
+ (tx_hash_hex, o) = c.constructor(signer_address, config.get('_ADDRESS_DECLARATOR'))
+ if config.get('_RPC_SEND'):
+ conn.do(o)
+ if config.get('_WAIT'):
+ r = conn.wait(tx_hash_hex)
+ if r['status'] == 0:
+ sys.stderr.write('EVM revert while deploying contract. Wish I had more to tell you')
+ sys.exit(1)
+ # TODO: pass through translator for keys (evm tester uses underscore instead of camelcase)
+ address = r['contractAddress']
+
+ print(address)
+ else:
+ print(tx_hash_hex)
+ else:
+ print(o)
+
+
+if __name__ == '__main__':
+ main()
diff --git a/python/requirements.txt b/python/requirements.txt
@@ -1,4 +1,4 @@
confini>=0.3.6rc3,<0.5.0
-crypto-dev-signer>=0.4.15a1,<=0.4.15
-chainlib-eth>=0.0.9a3,<=0.1.0
-eth_erc20>=0.1.2a2,<=0.2.0
+crypto-dev-signer>=0.4.15rc2,<=0.4.15
+chainlib-eth>=0.0.9a13,<=0.1.0
+eth_erc20>=0.1.2a3,<=0.2.0