ea6954f72f
Change Idb7780f55e4a1fd77dd76becbf67c1ccbf220db7 restructured the python inventory generation code so that it would be possible to install it with pip. This change removes (most) of the import path hacks and switches to using a pip-installed version of osa_toolkit. Of note, the path hacks are left in place for the dynamic_inventory.py file for now, as that file is really more of an endpoint, but is tested. Also, the bootstrap-ansible.sh script was modified to install the code; this is unnecessary with the tox environments because the tox directive 'usedevelop=True' does that already. Production environments still need this, though. Finally, to maintain usability when called directly, the interpreter for dynamic_inventory.py was updated from `/usr/bin/env` to `/opt/ansible-runime/python`. This change ensures that in a full deployment the user is using the exact same code paths whether Ansible invokes the script, or it is called directly. This also means that using the script locally on a development machine, it must be invoked as an argument to Python, unless the ansible-runtime directory exists. Change-Id: Iafa573b1b144f98528d5e0aceb3f36e9de2a22a2
82 lines
2.3 KiB
Python
Executable File
82 lines
2.3 KiB
Python
Executable File
#!/opt/ansible-runtime/bin/python
|
|
# Copyright 2014, Rackspace US, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
# (c) 2014, Kevin Carter <kevin.carter@rackspace.com>
|
|
|
|
import argparse
|
|
import os
|
|
import sys
|
|
|
|
try:
|
|
from osa_toolkit import generate
|
|
except ImportError:
|
|
current_path = os.path.abspath(os.path.dirname(os.path.realpath(__file__)))
|
|
lib_path = os.path.join(current_path, '..', '..', 'osa_toolkit')
|
|
sys.path.append(lib_path)
|
|
from osa_toolkit import generate
|
|
|
|
|
|
# Function kept in order to use relative pathing for the env.d directory
|
|
def args(arg_list):
|
|
"""Setup argument Parsing."""
|
|
parser = argparse.ArgumentParser(
|
|
usage='%(prog)s',
|
|
description='OpenStack Inventory Generator',
|
|
epilog='Inventory Generator Licensed "Apache 2.0"')
|
|
|
|
parser.add_argument(
|
|
'--config',
|
|
help='Path containing the user defined configuration files',
|
|
required=False,
|
|
default=None
|
|
)
|
|
parser.add_argument(
|
|
'--list',
|
|
help='List all entries',
|
|
action='store_true'
|
|
)
|
|
|
|
parser.add_argument(
|
|
'--check',
|
|
help="Configuration check only, don't generate inventory",
|
|
action='store_true',
|
|
)
|
|
|
|
parser.add_argument(
|
|
'-d',
|
|
'--debug',
|
|
help=('Output debug messages to log file. '
|
|
'File is appended to, not overwritten'),
|
|
action='store_true',
|
|
default=False,
|
|
)
|
|
|
|
parser.add_argument(
|
|
'-e',
|
|
'--environment',
|
|
help=('Directory that contains the base env.d directory.\n'
|
|
'Defaults to <OSA_ROOT>/playbooks/inventory/.'),
|
|
required=False,
|
|
default=os.path.dirname(__file__),
|
|
)
|
|
|
|
return vars(parser.parse_args(arg_list))
|
|
|
|
|
|
if __name__ == '__main__':
|
|
all_args = args(sys.argv[1:])
|
|
output = generate.main(**all_args)
|
|
print(output)
|