fixed virtualbox plugins, expanded docs
This commit is contained in:
parent
46a3e6088b
commit
5cd0074831
1 changed files with 29 additions and 20 deletions
|
@ -23,7 +23,7 @@ DOCUMENTATION:
|
||||||
short_description: virtualbox inventory source
|
short_description: virtualbox inventory source
|
||||||
description:
|
description:
|
||||||
- Get inventory hosts from the local virtualbox installation.
|
- Get inventory hosts from the local virtualbox installation.
|
||||||
- Uses a <name>.vbox.conf YAML configuration file.
|
- Uses a <name>.vbox.yaml (or .vbox.yml) YAML configuration file.
|
||||||
options:
|
options:
|
||||||
running_only:
|
running_only:
|
||||||
description: toggles showing all vms vs only those currently running
|
description: toggles showing all vms vs only those currently running
|
||||||
|
@ -33,10 +33,19 @@ DOCUMENTATION:
|
||||||
network_info_path:
|
network_info_path:
|
||||||
description: property path to query for network information (ansible_host)
|
description: property path to query for network information (ansible_host)
|
||||||
default: "/VirtualBox/GuestInfo/Net/0/V4/IP"
|
default: "/VirtualBox/GuestInfo/Net/0/V4/IP"
|
||||||
|
EXAMPLES:
|
||||||
|
# file must be named vbox.yaml or vbox.yml
|
||||||
|
simple_config_file:
|
||||||
|
plugin: virtualbox
|
||||||
|
settings_password_file: /etc/virtulbox/secrets
|
||||||
|
compose:
|
||||||
|
ansible_connection: ('indows' in vbox_Guest_OS)|ternary('winrm', 'ssh')
|
||||||
'''
|
'''
|
||||||
from __future__ import (absolute_import, division, print_function)
|
from __future__ import (absolute_import, division, print_function)
|
||||||
__metaclass__ = type
|
__metaclass__ = type
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
from subprocess import Popen, PIPE
|
from subprocess import Popen, PIPE
|
||||||
|
|
||||||
from ansible.errors import AnsibleParserError
|
from ansible.errors import AnsibleParserError
|
||||||
|
@ -53,7 +62,8 @@ class InventoryModule(BaseInventoryPlugin):
|
||||||
|
|
||||||
valid = False
|
valid = False
|
||||||
if super(InventoryModule, self).verify_file(path):
|
if super(InventoryModule, self).verify_file(path):
|
||||||
if path.endswith('.vbox.conf'):
|
print(path)
|
||||||
|
if path.endswith('.vbox.yaml') or path.endswith('.vbox.yml'):
|
||||||
valid = True
|
valid = True
|
||||||
return valid
|
return valid
|
||||||
|
|
||||||
|
@ -64,20 +74,20 @@ class InventoryModule(BaseInventoryPlugin):
|
||||||
VBOX = "VBoxManage"
|
VBOX = "VBoxManage"
|
||||||
cache_key = self.get_cache_prefix(path)
|
cache_key = self.get_cache_prefix(path)
|
||||||
|
|
||||||
if cache and cache_key not in inventory.cache:
|
# file is config file
|
||||||
|
try:
|
||||||
|
data = self.loader.load_from_file(path)
|
||||||
|
except Exception as e:
|
||||||
|
raise AnsibleParserError(e)
|
||||||
|
|
||||||
|
if not data or data.get('plugin') != self.NAME:
|
||||||
|
# this is not my config file
|
||||||
|
return False
|
||||||
|
|
||||||
|
if cache and cache_key in inventory.cache:
|
||||||
source_data = inventory.cache[cache_key]
|
source_data = inventory.cache[cache_key]
|
||||||
else:
|
else:
|
||||||
# file is config file
|
|
||||||
try:
|
|
||||||
data = self.loader.load_from_file(path)
|
|
||||||
except Exception as e:
|
|
||||||
raise AnsibleParserError(e)
|
|
||||||
|
|
||||||
if not data or data.get('plugin') != self.NAME:
|
|
||||||
return False
|
|
||||||
|
|
||||||
pwfile = to_bytes(data.get('settings_password_file'))
|
pwfile = to_bytes(data.get('settings_password_file'))
|
||||||
netinfo = data.get('network_info_path', "/VirtualBox/GuestInfo/Net/0/V4/IP")
|
|
||||||
running = data.get('running_only', False)
|
running = data.get('running_only', False)
|
||||||
|
|
||||||
# start getting data
|
# start getting data
|
||||||
|
@ -96,15 +106,16 @@ class InventoryModule(BaseInventoryPlugin):
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
AnsibleParserError(e)
|
AnsibleParserError(e)
|
||||||
|
|
||||||
hostvars = {}
|
|
||||||
prevkey = pref_k = ''
|
|
||||||
current_host = None
|
|
||||||
|
|
||||||
source_data = p.stdout.readlines()
|
source_data = p.stdout.readlines()
|
||||||
inventory.cache[cache_key] = source_data
|
inventory.cache[cache_key] = source_data
|
||||||
|
|
||||||
for line in source_data:
|
hostvars = {}
|
||||||
|
prevkey = pref_k = ''
|
||||||
|
current_host = None
|
||||||
|
|
||||||
|
netinfo = data.get('network_info_path', "/VirtualBox/GuestInfo/Net/0/V4/IP")
|
||||||
|
|
||||||
|
for line in source_data:
|
||||||
try:
|
try:
|
||||||
k, v = line.split(':', 1)
|
k, v = line.split(':', 1)
|
||||||
except:
|
except:
|
||||||
|
@ -125,8 +136,6 @@ class InventoryModule(BaseInventoryPlugin):
|
||||||
# try to get network info
|
# try to get network info
|
||||||
try:
|
try:
|
||||||
cmd = [VBOX, 'guestproperty', 'get', current_host, netinfo]
|
cmd = [VBOX, 'guestproperty', 'get', current_host, netinfo]
|
||||||
if args:
|
|
||||||
cmd.append(args)
|
|
||||||
x = Popen(cmd, stdout=PIPE)
|
x = Popen(cmd, stdout=PIPE)
|
||||||
ipinfo = x.stdout.read()
|
ipinfo = x.stdout.read()
|
||||||
if 'Value' in ipinfo:
|
if 'Value' in ipinfo:
|
||||||
|
|
Loading…
Reference in a new issue