Initial commit

This commit is contained in:
nolash 2021-11-05 07:21:33 +01:00
commit c55af204cc
Signed by: lash
GPG Key ID: 21D2E7BB88C2A746
7 changed files with 113 additions and 0 deletions

1
clicada/cli/__init__.py Normal file
View File

@ -0,0 +1 @@
from clicada.cli.arg import CmdCtrl

64
clicada/cli/arg.py Normal file
View File

@ -0,0 +1,64 @@
# standard imports
import os
import argparse
import logging
import importlib
# external imports
import confini
# local imports
import clicada.cli.user as cmd_user
script_dir = os.path.dirname(os.path.realpath(__file__))
data_dir = os.path.join(script_dir, '..', 'data')
base_config_dir = os.path.join(data_dir, 'config')
class CmdCtrl:
__cmd_alias = {
'u': 'user',
}
def __init__(self, argv=None, description=None, logger=None, *args, **kwargs):
self.argparser = argparse.ArgumentParser(description=description, *args, **kwargs)
self.argparser.add_argument('-c', type=str, help='Configuration override directory path')
self.argparser.add_argument('-v', action='store_true', help='Be verbose')
self.argparser.add_argument('-vv', action='store_true', help='Be very verbose')
sub = self.argparser.add_subparsers()
sub.dest = 'command'
sub_user = sub.add_parser('user', aliases=['u'], help='retrieve transactions for a user')
cmd_user.process_args(sub_user)
self.cmd_args = self.argparser.parse_args(argv)
if logger == None:
logger = logging.getLogger()
if self.cmd_args.vv:
logger.setLevel(logging.DEBUG)
elif self.cmd_args.v:
logger.setLevel(logging.INFO)
self.cmd_string = self.cmd_args.command
cmd_string_translate = self.__cmd_alias.get(self.cmd_string)
if cmd_string_translate != None:
self.cmd_string = cmd_string_translate
if self.cmd_string == None:
raise ValueError('Subcommand missing')
modname = 'clicada.cli.{}'.format(self.cmd_string)
logger.debug('using module {}'.format(modname))
self.cmd_mod = importlib.import_module(modname)
if self.cmd_args.c:
self.config = confini.Config(base_config_dir, override_dirs=self.cmd_args.c)
else:
self.config = confini.Config(base_config_dir)
self.config.process()
logger.debug('loaded config:\n{}'.format(self.config))

15
clicada/cli/user.py Normal file
View File

@ -0,0 +1,15 @@
def process_args(argparser):
argparser.add_argument('-m', '--method', type=str, help='lookup method')
argparser.add_argument('identifier', type=str, help='user identifier')
def validate_args(args):
pass
def apply_args(config, args):
pass
def execute(config, args):
pass

View File

@ -0,0 +1,2 @@
[meta]
lookup_method = phone

12
clicada/runnable/view.py Normal file
View File

@ -0,0 +1,12 @@
# standard imports
import sys
import logging
# local imports
from clicada.tx import TxGetter
from clicada.cli import CmdCtrl
logging.basicConfig(level=logging.WARNING)
logg = logging.getLogger()
ctrl = CmdCtrl(argv=sys.argv[1:], logger=logg)

17
clicada/tx.py Normal file
View File

@ -0,0 +1,17 @@
# standard imports
import urllib.request
import urllib.parse
class TxGetter:
def __init__(self, cache_url, limit=0):
self.cache_url = cache_url
self.limit = limit
if limit == 0:
url = urllib.parse.urljoin(self.cache_url, 'defaultlimit')
r = urllib.request.urlopen(url)
self.limit = r.read()
logg.debug('set limit {} from {}'.format(self.limit, self.cache_url))

2
requirements.txt Normal file
View File

@ -0,0 +1,2 @@
usumbufu~=0.3.2
confini~=0.5.1