mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-04-28 21:31:26 -07:00
* Ansible Config part2 - made dump_me nicer, added note this is not prod - moved internal key removal function to vars - carry tracebacks in errors we can now show tracebacks for plugins on vvv - show inventory plugin tracebacks on vvv - minor fixes to cg groups plugin - draft config from plugin docs - made search path warning 'saner' (top level dirs only) - correctly display config entries and others - removed unneeded code - commented out some conn plugin specific from base.yml - also deprecated sudo/su - updated ssh conn docs - shared get option method for connection plugins - note about needing eval for defaults - tailored yaml ext - updated strategy entry - for connection pliugins, options load on plugin load - allow for long types in definitions - better display in ansible-doc - cleaned up/updated source docs and base.yml - added many descriptions - deprecated include toggles as include is - draft backwards compat get_config - fixes to ansible-config, added --only-changed - some code reoorg - small license headers - show default in doc type - pushed module utils details to 5vs - work w/o config file - PEPE ATE! - moved loader to it's own file - fixed rhn_register test - fixed boto requirement in make tests - I ate Pepe - fixed dynamic eval of defaults - better doc code skip ipaddr filter tests when missing netaddr removed devnull string from config better becoem resolution * killed extra space with extreeme prejudice cause its an affront against all that is holy that 2 spaces touch each other! shippable timing out on some images, but merging as it passes most
45 lines
1.5 KiB
Python
45 lines
1.5 KiB
Python
# Copyright (c) 2017 Ansible Project
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
# Make coding more python3-ish
|
|
from __future__ import (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
|
|
class ConfigData(object):
|
|
|
|
def __init__(self):
|
|
self._global_settings = {}
|
|
self._plugins = {}
|
|
|
|
def get_setting(self, name, plugin=None):
|
|
|
|
setting = None
|
|
if plugin is None:
|
|
setting = self._global_settings.get(name)
|
|
elif plugin.type in self._plugins and plugin.name in self._plugins[plugin.type]:
|
|
setting = self._plugins[plugin.type][plugin.name].get(name)
|
|
|
|
return setting
|
|
|
|
def get_settings(self, plugin=None):
|
|
|
|
settings = []
|
|
if plugin is None:
|
|
settings = [ self._global_settings[k] for k in self._global_settings ]
|
|
elif plugin.type in self._plugins and plugin.name in self._plugins[plugin.type]:
|
|
settings = [ self._plugins[plugin.type][plugin.name][k] for k in self._plugins[plugin.type][plugin.name] ]
|
|
|
|
return settings
|
|
|
|
def update_setting(self, setting, plugin=None):
|
|
|
|
if plugin is None:
|
|
self._global_settings[setting.name] = setting
|
|
else:
|
|
if plugin.type not in self._plugins:
|
|
self._plugins[plugin.type] = {}
|
|
if plugin.name not in self._plugins[plugin.type]:
|
|
self._plugins[plugin.type][plugin.name] = {}
|
|
self._plugins[plugin.type][plugin.name][setting.name] = setting
|
|
|