summaryrefslogtreecommitdiffstats
path: root/ci/genPublicAPIProxyBundle.py
blob: 87acee2c5bd35c910e9f13c3b8dbadcced4d91aa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#!/usr/bin/python
# -*- coding: utf-8 -*-

"""
This script generates a bundle config for the haproxy managing public apis

Parameters:
 -l, --lab      : lab config file
"""

from jinja2 import Environment, FileSystemLoader
from keystoneauth1.identity import v2
from keystoneauth1 import session
from keystoneclient.v2_0 import client
from optparse import OptionParser

import os
import yaml

#
# Parse parameters
#

parser = OptionParser()
parser.add_option("-l", "--lab", dest="lab", help="lab config file")
(options, args) = parser.parse_args()
labconfig_file = options.lab

#
# Set Path and configs path
#

# Capture our current directory
TPL_DIR = os.path.dirname(os.path.abspath(__file__))+'/config_tpl'

#
# Local Functions
#


def load_yaml(filepath):
    """Load YAML file"""
    with open(filepath, 'r') as stream:
        try:
            return yaml.load(stream)
        except yaml.YAMLError as exc:
            print(exc)

#
# Config import
#

# Load scenario Config
config = load_yaml(labconfig_file)

# Add public api ip to config
if 'public_api_ip' in config['lab']['racks'][0]:
    config['public_api_ip'] = config['lab']['racks'][0]['public_api_ip']
else:
    first_public_ip = config['lab']['racks'][0][
                        'floating-ip-range'].split(',')[0]
    # managing ipv6 and ipv4 format
    sep = ':' if ':' in first_public_ip else '.'
    api_ip = first_public_ip.split(sep)
    api_ip[-1] = str(int(api_ip[-1])-1)
    config['public_api_ip'] = sep.join(api_ip)

# get endpoint list from keystone
username = os.environ['OS_USERNAME']
password = os.environ['OS_PASSWORD']
tenant_name = os.environ['OS_TENANT_NAME']
auth_url = os.environ['OS_AUTH_URL']
auth = v2.Password(username=username,
                   password=password,
                   tenant_name=tenant_name,
                   auth_url=auth_url)
sess = session.Session(auth=auth)
keystone = client.Client(session=sess)
services = keystone.services.list()
endpoints = keystone.endpoints.list()
srv = dict()
for service in services:
    if service.name != 'cinderv2':
        srv[service.id] = {'name': service.name}
for endpoint in endpoints:
    if endpoint.service_id in srv.keys():
        internal = endpoint.internalurl.split('/')[2].split(':')
        srv[endpoint.service_id]['ip'] = ':'.join(internal[:-1])
        srv[endpoint.service_id]['port'] = internal[-1]
config['public_api_services'] = srv

#
# Transform template to deployconfig.yaml according to config
#

# Create the jinja2 environment.
env = Environment(loader=FileSystemLoader(TPL_DIR),
                  trim_blocks=True)
template = env.get_template('public-api-proxy.yaml')

# Render the template
output = template.render(**config)

# Check output syntax
try:
    yaml.load(output)
except yaml.YAMLError as exc:
    print(exc)

# print output
print(output)