Skip to content

Commit

Permalink
[4639] Migrate command to cli folder.
Browse files Browse the repository at this point in the history
  • Loading branch information
pdelboca committed Jun 27, 2019
1 parent f07e0c4 commit c17dc22
Show file tree
Hide file tree
Showing 2 changed files with 83 additions and 0 deletions.
2 changes: 2 additions & 0 deletions ckan/cli/cli.py
Expand Up @@ -11,6 +11,7 @@
datastore,
translation,
dataset,
plugin_info,
)

from ckan.config.middleware import make_app
Expand Down Expand Up @@ -44,3 +45,4 @@ def ckan(ctx, config, *args, **kwargs):
ckan.add_command(datastore.datastore)
ckan.add_command(translation.translation)
ckan.add_command(dataset.dataset)
ckan.add_command(plugin_info.plugin_info)
81 changes: 81 additions & 0 deletions ckan/cli/plugin_info.py
@@ -0,0 +1,81 @@
import click

@click.command(name=u'plugin-info', short_help='Provide info on installed plugins.')
def plugin_info():
''' print info about current plugins from the .ini file'''
import ckan.plugins as p
interfaces = {}
plugins = {}
for name in dir(p):
item = getattr(p, name)
try:
if issubclass(item, p.Interface):
interfaces[item] = {'class': item}
except TypeError:
pass

for interface in interfaces:
for plugin in p.PluginImplementations(interface):
name = plugin.name
if name not in plugins:
plugins[name] = {'doc': plugin.__doc__,
'class': plugin,
'implements': []}
plugins[name]['implements'].append(interface.__name__)

for plugin in plugins:
p = plugins[plugin]
click.echo(plugin + ':')
click.echo('-' * (len(plugin) + 1))
if p['doc']:
click.echo(p['doc'])
click.echo('Implements:')
for i in p['implements']:
extra = None
if i == 'ITemplateHelpers':
extra = _template_helpers(p['class'])
if i == 'IActions':
extra = _actions(p['class'])
click.echo(' %s' % i)
if extra:
click.echo(extra)
click.echo()

def _template_helpers(cls):
''' Return readable helper function info. '''
helpers = cls.get_helpers()
return _function_info(helpers)

def _actions(self, cls):
''' Return readable action function info. '''
actions = cls.get_actions()
return _function_info(actions)

def _function_info(functions):
''' Take a dict of functions and output readable info '''
import inspect
output = []
for function_name in functions:
fn = functions[function_name]
args_info = inspect.getargspec(fn)
params = args_info.args
num_params = len(params)
if args_info.varargs:
params.append('*' + args_info.varargs)
if args_info.keywords:
params.append('**' + args_info.keywords)
if args_info.defaults:
offset = num_params - len(args_info.defaults)
for i, v in enumerate(args_info.defaults):
params[i + offset] = params[i + offset] + '=' + repr(v)
# is this a classmethod if so remove the first parameter
if inspect.ismethod(fn) and inspect.isclass(fn.__self__):
params = params[1:]
params = ', '.join(params)
output.append(' %s(%s)' % (function_name, params))
# doc string
if fn.__doc__:
bits = fn.__doc__.split('\n')
for bit in bits:
output.append(' %s' % bit)
return ('\n').join(output)

0 comments on commit c17dc22

Please sign in to comment.