Brook inventory (#16122)

* Do not ask for templates in Brook inventory if they do not exist

* Add availability zone variable to Brook inventory

* Add provider id variable to Brook inventory

* Error output sent to stderr in Brook inventory
This commit is contained in:
Francisco Ros 2017-03-27 20:54:33 +02:00 committed by Brian Coca
parent 73438de862
commit 0fa797030e

View file

@ -32,11 +32,13 @@ included, provided the requesting user belongs to it.
The following variables are established for every host. They can be retrieved from the hostvars The following variables are established for every host. They can be retrieved from the hostvars
dictionary. dictionary.
- brook_pid: str
- brook_name: str - brook_name: str
- brook_description: str - brook_description: str
- brook_project: str - brook_project: str
- brook_template: str - brook_template: str
- brook_region: str - brook_region: str
- brook_zone: str
- brook_status: str - brook_status: str
- brook_tags: list(str) - brook_tags: list(str)
- brook_internal_ips: list(str) - brook_internal_ips: list(str)
@ -70,7 +72,7 @@ Support:
This script is tested on Python 2.7 and 3.4. It may work on other versions though. This script is tested on Python 2.7 and 3.4. It may work on other versions though.
Author: Francisco Ros <fjros@doalitic.com> Author: Francisco Ros <fjros@doalitic.com>
Version: 0.1 Version: 0.2
""" """
@ -122,9 +124,8 @@ class BrookInventory:
self.project_id = config.get('brook', 'project_id') self.project_id = config.get('brook', 'project_id')
if not self.api_token: if not self.api_token:
print('You must provide (at least) your Brook.io API token to generate the dynamic ' sys.exit('You must provide (at least) your Brook.io API token to generate the dynamic '
'inventory.') 'inventory.')
sys.exit(1)
def get_api_client(self): def get_api_client(self):
"""Authenticate user via the provided credentials and return the corresponding API client. """Authenticate user via the provided credentials and return the corresponding API client.
@ -168,8 +169,8 @@ class BrookInventory:
for project_id in projects: for project_id in projects:
project = projects_api.show_project(project_id=project_id) project = projects_api.show_project(project_id=project_id)
for instance in instances_api.index_instances(project_id=project_id): for instance in instances_api.index_instances(project_id=project_id):
# Get template used for this instance # Get template used for this instance if known
template = templates_api.show_template(template_id=instance.template) template = templates_api.show_template(template_id=instance.template) if instance.template else None
# Update hostvars # Update hostvars
try: try:
@ -212,11 +213,13 @@ class BrookInventory:
""" """
hostvars = instance.to_dict() hostvars = instance.to_dict()
hostvars['brook_pid'] = hostvars.pop('pid')
hostvars['brook_name'] = hostvars.pop('name') hostvars['brook_name'] = hostvars.pop('name')
hostvars['brook_description'] = hostvars.pop('description') hostvars['brook_description'] = hostvars.pop('description')
hostvars['brook_project'] = hostvars.pop('project') hostvars['brook_project'] = hostvars.pop('project')
hostvars['brook_template'] = hostvars.pop('template') hostvars['brook_template'] = hostvars.pop('template')
hostvars['brook_region'] = hostvars.pop('region') hostvars['brook_region'] = hostvars.pop('region')
hostvars['brook_zone'] = hostvars.pop('zone')
hostvars['brook_created_at'] = hostvars.pop('created_at') hostvars['brook_created_at'] = hostvars.pop('created_at')
hostvars['brook_updated_at'] = hostvars.pop('updated_at') hostvars['brook_updated_at'] = hostvars.pop('updated_at')
del hostvars['id'] del hostvars['id']
@ -227,7 +230,7 @@ class BrookInventory:
# Substitute identifiers for names # Substitute identifiers for names
# #
hostvars['brook_project'] = project.name hostvars['brook_project'] = project.name
hostvars['brook_template'] = template.name hostvars['brook_template'] = template.name if template else None
# Retrieve instance state # Retrieve instance state
# #