mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-12 17:21:55 -06:00
9a21964877
Move the code that generated result of the `plugins` command from API to the command itself. https://fedorahosted.org/freeipa/ticket/4427 Reviewed-By: David Kupka <dkupka@redhat.com>
146 lines
4.1 KiB
Python
146 lines
4.1 KiB
Python
# Authors:
|
|
# Jason Gerard DeRose <jderose@redhat.com>
|
|
#
|
|
# Copyright (C) 2008 Red Hat
|
|
# see file 'COPYING' for use and warranty information
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
import re
|
|
from ipalib import LocalOrRemote, _, ngettext
|
|
from ipalib.output import Output, summary
|
|
from ipalib import Flag
|
|
from ipalib.plugable import Registry
|
|
|
|
__doc__ = _("""
|
|
Misc plug-ins
|
|
""")
|
|
|
|
register = Registry()
|
|
|
|
# FIXME: We should not let env return anything in_server
|
|
# when mode == 'production'. This would allow an attacker to see the
|
|
# configuration of the server, potentially revealing compromising
|
|
# information. However, it's damn handy for testing/debugging.
|
|
|
|
|
|
@register()
|
|
class env(LocalOrRemote):
|
|
__doc__ = _('Show environment variables.')
|
|
|
|
msg_summary = _('%(count)d variables')
|
|
|
|
takes_args = (
|
|
'variables*',
|
|
)
|
|
|
|
takes_options = LocalOrRemote.takes_options + (
|
|
Flag('all',
|
|
cli_name='all',
|
|
doc=_('retrieve and print all attributes from the server. Affects command output.'),
|
|
exclude='webui',
|
|
flags=['no_option', 'no_output'],
|
|
default=True,
|
|
),
|
|
)
|
|
|
|
has_output = (
|
|
Output('result',
|
|
type=dict,
|
|
doc=_('Dictionary mapping variable name to value'),
|
|
),
|
|
Output('total',
|
|
type=int,
|
|
doc=_('Total number of variables env (>= count)'),
|
|
flags=['no_display'],
|
|
),
|
|
Output('count',
|
|
type=int,
|
|
doc=_('Number of variables returned (<= total)'),
|
|
flags=['no_display'],
|
|
),
|
|
summary,
|
|
)
|
|
|
|
def __find_keys(self, variables):
|
|
keys = set()
|
|
for query in variables:
|
|
if '*' in query:
|
|
pat = re.compile(query.replace('*', '.*') + '$')
|
|
for key in self.env:
|
|
if pat.match(key):
|
|
keys.add(key)
|
|
elif query in self.env:
|
|
keys.add(query)
|
|
return keys
|
|
|
|
def execute(self, variables=None, **options):
|
|
if variables is None:
|
|
keys = self.env
|
|
else:
|
|
keys = self.__find_keys(variables)
|
|
ret = dict(
|
|
result=dict(
|
|
(key, self.env[key]) for key in keys
|
|
),
|
|
count=len(keys),
|
|
total=len(self.env),
|
|
)
|
|
if len(keys) > 1:
|
|
ret['summary'] = self.msg_summary % ret
|
|
else:
|
|
ret['summary'] = None
|
|
return ret
|
|
|
|
|
|
|
|
@register()
|
|
class plugins(LocalOrRemote):
|
|
__doc__ = _('Show all loaded plugins.')
|
|
|
|
msg_summary = ngettext(
|
|
'%(count)d plugin loaded', '%(count)d plugins loaded', 0
|
|
)
|
|
|
|
takes_options = LocalOrRemote.takes_options + (
|
|
Flag('all',
|
|
cli_name='all',
|
|
doc=_('retrieve and print all attributes from the server. Affects command output.'),
|
|
exclude='webui',
|
|
flags=['no_option', 'no_output'],
|
|
default=True,
|
|
),
|
|
)
|
|
|
|
has_output = (
|
|
Output('result', dict, 'Dictionary mapping plugin names to bases'),
|
|
Output('count',
|
|
type=int,
|
|
doc=_('Number of plugins loaded'),
|
|
),
|
|
summary,
|
|
)
|
|
|
|
def execute(self, **options):
|
|
result = {}
|
|
for namespace in self.api:
|
|
for plugin in self.api[namespace]():
|
|
cls = type(plugin)
|
|
key = '{}.{}'.format(cls.__module__, cls.__name__)
|
|
result.setdefault(key, []).append(namespace)
|
|
|
|
return dict(
|
|
result=result,
|
|
)
|