6e585bdf24
Add deps/requires for fact collectors Fact collectors can now set a required_facts class attribute that will be a set of the names of fact collectors they require to be run first. ie, if a collector needs to know the ansible_distribution, it should set it's required_facts to include 'distribution' required_facts = set(['distribution']) If a collector requires another collector, it gets added to the selected collector names. We then topological sort the ordering of the collectors so that deps work out (ie, 'distribution' will run before 'service_mgr') required_facts were added to the collectors for: - network (requires 'distribution', 'platform') - hardware (requires 'platform') - service_mgr (requires 'distribution', 'platform') Fix name references for facts (need 'ansible_' prefix) is service_mgr Fixes #30753
50 lines
1.1 KiB
Python
50 lines
1.1 KiB
Python
# (c) 2014, Brian Coca, Josh Drake, et al
|
|
# (c) 2017 Ansible Project
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
from ansible.plugins.cache import BaseCacheModule
|
|
|
|
DOCUMENTATION = '''
|
|
cache: none
|
|
short_description: write-only cache (no cache)
|
|
description:
|
|
- No caching at all
|
|
version_added: historical
|
|
author: core team (@ansible-core)
|
|
'''
|
|
|
|
|
|
class CacheModule(BaseCacheModule):
|
|
def __init__(self, *args, **kwargs):
|
|
self.empty = {}
|
|
|
|
def get(self, key):
|
|
return self.empty.get(key)
|
|
|
|
def set(self, key, value):
|
|
return value
|
|
|
|
def keys(self):
|
|
return self.empty.keys()
|
|
|
|
def contains(self, key):
|
|
return key in self.empty
|
|
|
|
def delete(self, key):
|
|
del self.emtpy[key]
|
|
|
|
def flush(self):
|
|
self.empty = {}
|
|
|
|
def copy(self):
|
|
return self.empty.copy()
|
|
|
|
def __getstate__(self):
|
|
return self.copy()
|
|
|
|
def __setstate__(self, data):
|
|
self.empty = data
|