support for _meta retrieval

This commit is contained in:
dmccue 2015-07-23 15:18:58 +01:00 committed by James Cammarata
parent a91428c65c
commit 0ab970da98

View file

@ -30,9 +30,14 @@ See http://ansible.github.com/api.html for more info
Tested with Cobbler 2.0.11. Tested with Cobbler 2.0.11.
Changelog: Changelog:
- 2015-06-21 dmccue: Heavily modified to support run-once _meta retrieval, results in
higher performance at ansible startup. Groups are determined by owner rather than
default mgmt_classes. DNS name determined from hostname.
- 2013-09-01 pgehres: Refactored implementation to make use of caching and to - 2013-09-01 pgehres: Refactored implementation to make use of caching and to
limit the number of connections to external cobbler server for performance. limit the number of connections to external cobbler server for performance.
Added use of cobbler.ini file to configure settings. Tested with Cobbler 2.4.0 Added use of cobbler.ini file to configure settings. Tested with Cobbler 2.4.0
""" """
# (c) 2012, Michael DeHaan <michael.dehaan@gmail.com> # (c) 2012, Michael DeHaan <michael.dehaan@gmail.com>
@ -54,7 +59,6 @@ Changelog:
###################################################################### ######################################################################
import argparse import argparse
import ConfigParser import ConfigParser
import os import os
@ -75,6 +79,7 @@ except ImportError:
class CobblerInventory(object): class CobblerInventory(object):
def __init__(self): def __init__(self):
""" Main execution path """ """ Main execution path """
self.conn = None self.conn = None
@ -97,14 +102,14 @@ class CobblerInventory(object):
data_to_print = "" data_to_print = ""
# Data to print # Data to print
if self.args.host: #if self.args.host:
data_to_print = self.get_host_info() # data_to_print = self.get_host_info()
self.inventory['_meta'] = { 'hostvars': {} }
for hostname in self.cache:
self.inventory['_meta']['hostvars'][hostname] = {'cobbler': self.cache[hostname] }
elif self.args.list:
# Display list of instances for inventory
data_to_print = self.json_format_dict(self.inventory, True)
else: # default action with no options
data_to_print = self.json_format_dict(self.inventory, True) data_to_print = self.json_format_dict(self.inventory, True)
print data_to_print print data_to_print
@ -144,7 +149,7 @@ class CobblerInventory(object):
parser = argparse.ArgumentParser(description='Produce an Ansible Inventory file based on Cobbler') parser = argparse.ArgumentParser(description='Produce an Ansible Inventory file based on Cobbler')
parser.add_argument('--list', action='store_true', default=True, help='List instances (default: True)') parser.add_argument('--list', action='store_true', default=True, help='List instances (default: True)')
parser.add_argument('--host', action='store', help='Get all the variables about a specific instance') #parser.add_argument('--host', action='store', help='Get all the variables about a specific instance')
parser.add_argument('--refresh-cache', action='store_true', default=False, parser.add_argument('--refresh-cache', action='store_true', default=False,
help='Force refresh of cache by making API requests to cobbler (default: False - use cache files)') help='Force refresh of cache by making API requests to cobbler (default: False - use cache files)')
self.args = parser.parse_args() self.args = parser.parse_args()
@ -160,21 +165,22 @@ class CobblerInventory(object):
for host in data: for host in data:
# Get the FQDN for the host and add it to the right groups # Get the FQDN for the host and add it to the right groups
dns_name = None dns_name = host['hostname'] #None
ksmeta = None ksmeta = None
interfaces = host['interfaces'] interfaces = host['interfaces']
for (iname, ivalue) in interfaces.iteritems(): #for (iname, ivalue) in interfaces.iteritems():
if ivalue['management']: # if ivalue['management']:
this_dns_name = ivalue.get('dns_name', None) # this_dns_name = ivalue.get('dns_name', None)
if this_dns_name is not None and this_dns_name is not "": # #this_dns_name = ivalue.get('ip_address', None)
dns_name = this_dns_name # if this_dns_name is not None and this_dns_name is not "":
# dns_name = this_dns_name
if dns_name is None: if dns_name is None:
continue continue
status = host['status'] status = host['status']
profile = host['profile'] profile = host['profile']
classes = host['mgmt_classes'] classes = host['owners'] #host['mgmt_classes']
if status not in self.inventory: if status not in self.inventory:
self.inventory[status] = [] self.inventory[status] = []
@ -193,7 +199,7 @@ class CobblerInventory(object):
# The old way was ksmeta only -- provide backwards compatibility # The old way was ksmeta only -- provide backwards compatibility
self.cache[dns_name] = dict() self.cache[dns_name] = host #dict() # sub dict with host to output json
if "ks_meta" in host: if "ks_meta" in host:
for key, value in host["ks_meta"].iteritems(): for key, value in host["ks_meta"].iteritems():
self.cache[dns_name][key] = value self.cache[dns_name][key] = value
@ -242,7 +248,7 @@ class CobblerInventory(object):
def write_to_cache(self, data, filename): def write_to_cache(self, data, filename):
""" Writes data in JSON format to a file """ """ Writes data in JSON format to a file """
if data: print "DEBUG: data = " + str(data)
json_data = self.json_format_dict(data, True) json_data = self.json_format_dict(data, True)
cache = open(filename, 'w') cache = open(filename, 'w')
cache.write(json_data) cache.write(json_data)