add _meta in the list json

pull/9273/head
Mathieu GAUTHIER-LAFAYE 10 years ago
parent 3d62e55abe
commit 7c094c9379

@ -29,7 +29,18 @@ class ProxmoxNodeList(list):
def get_names(self):
return [node['node'] for node in self]
class ProxmoxQemu(dict):
def get_variables(self):
variables = {}
for key, value in self.iteritems():
variables['proxmox_' + key] = value
return variables
class ProxmoxQemuList(list):
def __init__(self, data=[]):
for item in data:
self.append(ProxmoxQemu(item))
def get_names(self):
return [qemu['name'] for qemu in self if qemu['template'] != 1]
@ -37,6 +48,13 @@ class ProxmoxQemuList(list):
results = [qemu for qemu in self if qemu['name'] == name]
return results[0] if len(results) > 0 else None
def get_variables(self):
variables = {}
for qemu in self:
variables[qemu['name']] = qemu.get_variables()
return variables
class ProxmoxPoolList(list):
def get_names(self):
return [pool['poolid'] for pool in self]
@ -95,40 +113,42 @@ class ProxmoxAPI(object):
return ProxmoxPool(self.get('api2/json/pools/{}'.format(poolid)))
def main_list(options):
result = {}
results = {
'all': {
'hosts': [],
},
'_meta': {
'hostvars': {},
}
}
proxmox_api = ProxmoxAPI(options)
proxmox_api.auth()
# all
result['all'] = []
for node in proxmox_api.nodes().get_names():
result['all'] += proxmox_api.node_qemu(node).get_names()
qemu_list = proxmox_api.node_qemu(node)
results['all']['hosts'] += qemu_list.get_names()
results['_meta']['hostvars'].update(qemu_list.get_variables())
# pools
for pool in proxmox_api.pools().get_names():
result[pool] = proxmox_api.pool(pool).get_members_name()
results[pool] = {
'hosts': proxmox_api.pool(pool).get_members_name(),
}
print json.dumps(result)
return json.dumps(results)
def main_host(options):
results = {}
proxmox_api = ProxmoxAPI(options)
proxmox_api.auth()
host = None
for node in proxmox_api.nodes().get_names():
qemu_list = proxmox_api.node_qemu(node)
qemu = qemu_list.get_by_name(options.host)
if qemu:
break
return json.dumps(qemu.get_variables())
if qemu:
for key, value in qemu.iteritems():
results['proxmox_' + key] = value
print json.dumps(results)
print json.dumps({})
def main():
parser = OptionParser(usage='%prog [options] --list | --host HOSTNAME')
@ -140,12 +160,14 @@ def main():
(options, args) = parser.parse_args()
if options.list:
main_list(options)
json = main_list(options)
elif options.host:
main_host(options)
json = main_host(options)
else:
parser.print_help()
sys.exit(1)
print json
if __name__ == '__main__':
main()

Loading…
Cancel
Save