2021-10-09 18:50:43 +02:00
|
|
|
# standard imports
|
|
|
|
import os
|
|
|
|
import logging
|
|
|
|
import argparse
|
|
|
|
import sys
|
|
|
|
import importlib
|
|
|
|
|
|
|
|
# external imports
|
2021-10-11 17:39:01 +02:00
|
|
|
import chainlib.cli
|
2021-10-09 18:50:43 +02:00
|
|
|
import cic.cmd.init as cmd_init
|
2021-10-09 20:37:54 +02:00
|
|
|
import cic.cmd.show as cmd_show
|
2021-10-18 10:47:48 +02:00
|
|
|
import cic.cmd.ext as cmd_ext
|
2021-10-09 21:04:11 +02:00
|
|
|
import cic.cmd.export as cmd_export
|
2021-10-09 18:50:43 +02:00
|
|
|
|
|
|
|
logging.basicConfig(level=logging.WARNING)
|
|
|
|
logg = logging.getLogger()
|
|
|
|
|
|
|
|
script_dir = os.path.dirname(os.path.realpath(__file__))
|
|
|
|
data_dir = os.path.join(script_dir, '..', 'data')
|
2021-10-11 17:39:01 +02:00
|
|
|
base_config_dir = os.path.join(data_dir, 'config')
|
2021-10-09 18:50:43 +02:00
|
|
|
schema_dir = os.path.join(script_dir, '..', 'schema')
|
|
|
|
|
2021-10-11 21:18:51 +02:00
|
|
|
arg_flags = chainlib.cli.argflag_std_read | chainlib.cli.Flag.SEQ
|
|
|
|
argparser = chainlib.cli.ArgumentParser(env=os.environ, arg_flags=arg_flags, description='CIC cli tool for generating and publishing tokens')
|
2021-10-09 18:50:43 +02:00
|
|
|
|
|
|
|
sub = argparser.add_subparsers()
|
|
|
|
sub.dest = 'command'
|
|
|
|
sub_init = sub.add_parser('init', help='initialize new cic data directory')
|
|
|
|
cmd_init.process_args(sub_init)
|
2021-10-09 20:37:54 +02:00
|
|
|
sub_show = sub.add_parser('show', help='display summary of current state of cic data directory')
|
|
|
|
cmd_show.process_args(sub_show)
|
2021-10-09 21:04:11 +02:00
|
|
|
sub_export = sub.add_parser('export', help='export cic data directory state to a specified target')
|
|
|
|
cmd_export.process_args(sub_export)
|
2021-10-18 10:47:48 +02:00
|
|
|
sub_ext = sub.add_parser('ext', help='extension helpers')
|
|
|
|
cmd_ext.process_args(sub_ext)
|
|
|
|
|
2021-10-09 18:50:43 +02:00
|
|
|
|
|
|
|
args = argparser.parse_args(sys.argv[1:])
|
|
|
|
|
|
|
|
if args.command == None:
|
|
|
|
logg.critical('Subcommand missing')
|
2021-12-05 08:12:36 +01:00
|
|
|
sys.stderr.write("\033[;91m" + 'subcommand missing' + "\033[;39m\n")
|
2021-10-09 18:50:43 +02:00
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
modname = 'cic.cmd.{}'.format(args.command)
|
|
|
|
logg.debug('using module {}'.format(modname))
|
|
|
|
cmd_mod = importlib.import_module(modname)
|
|
|
|
|
2021-10-11 21:18:51 +02:00
|
|
|
extra_args = {
|
|
|
|
'p': 'RPC_PROVIDER',
|
|
|
|
}
|
|
|
|
config = chainlib.cli.Config.from_args(args, arg_flags=arg_flags, base_config_dir=base_config_dir, extra_args=extra_args)
|
2021-10-09 18:50:43 +02:00
|
|
|
|
|
|
|
def main():
|
2021-12-05 08:12:36 +01:00
|
|
|
try:
|
|
|
|
cmd_mod.execute(config, args)
|
|
|
|
except Exception as e:
|
|
|
|
logg.exception(e) #'{}'.format(e))
|
|
|
|
sys.stderr.write("\033[;91m" + str(e) + "\033[;39m\n")
|
|
|
|
sys.exit(1)
|
2021-10-09 18:50:43 +02:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|