commit e4d6b8d8454fcef2aed7930dfb352bcad7da7cd4
parent 75c72b78283f2bd1e784ed16ccce0dc0789d7258
Author: nolash <dev@holbrook.no>
Date: Wed, 6 Oct 2021 07:30:07 +0200
Add option to generate abi encoding without method
Diffstat:
2 files changed, 17 insertions(+), 4 deletions(-)
diff --git a/chainlib/eth/runnable/encode.py b/chainlib/eth/runnable/encode.py
@@ -62,7 +62,11 @@ argparser = chainlib.eth.cli.ArgumentParser(arg_flags)
argparser.add_argument('--signature', type=str, help='Method signature to encode')
argparser.add_argument('contract_args', type=str, nargs='*', help='arguments to encode')
args = argparser.parse_args()
-config = chainlib.eth.cli.Config.from_args(args, arg_flags, default_config_dir=config_dir)
+extra_args = {
+ 'signature': None,
+ 'contract_args': None,
+ }
+config = chainlib.eth.cli.Config.from_args(args, arg_flags, extra_args=extra_args, default_config_dir=config_dir)
if not config.get('_EXEC_ADDRESS'):
argparser.error('exec address (-e) must be defined')
@@ -161,19 +165,24 @@ def main():
cli_encoder = CLIEncoder()
contract_encoder = ABIContractEncoder()
- if args.signature:
+ if config.get('_SIGNATURE'):
contract_encoder.method(args.signature)
- for arg in args.contract_args:
+ for arg in config.get('_CONTRACT_ARGS'):
logg.debug('arg {}'.format(arg))
(typ, val) = arg.split(':', maxsplit=1)
real_typ = cli_encoder.translate_type(typ)
- contract_encoder.typ(real_typ)
+ if config.get('_SIGNATURE'):
+ contract_encoder.typ(real_typ)
fn = getattr(contract_encoder, real_typ.value)
fn(val)
code += contract_encoder.get()
+ if not config.get('_SIGNATURE'):
+ print(strip_0x(code))
+ return
+
if signer == None:
c = TxFactory(chain_spec)
j = JSONRPCRequest(id_generator=rpc.id_generator)
@@ -212,6 +221,8 @@ def main():
r = conn.do(r)
print(r)
else:
+ if config.get('_RAW'):
+ o = strip_0x(o)
print(o)
if __name__ == '__main__':
diff --git a/chainlib/eth/runnable/raw.py b/chainlib/eth/runnable/raw.py
@@ -125,6 +125,8 @@ def main():
r = conn.do(o)
print(r)
else:
+ if config.get('_RAW'):
+ o = strip_0x(o)
print(o)
else: