blob: 73407c09e7bea9a821efed13d18baaa04835d92a [file] [log] [blame]
koder aka kdanilov168f6092015-04-19 02:33:38 +03001import os.path
Yulia Portnova0e64ea22015-03-20 17:27:22 +02002import logging
koder aka kdanilovcee43342015-04-14 22:52:53 +03003
koder aka kdanilovcff7b2e2015-04-18 20:48:15 +03004from . import ceph
5from . import fuel
6from . import openstack
7from wally.utils import parse_creds
Yulia Portnova0e64ea22015-03-20 17:27:22 +02008
9
koder aka kdanilovcff7b2e2015-04-18 20:48:15 +030010logger = logging.getLogger("wally.discover")
11
12
koder aka kdanilov168f6092015-04-19 02:33:38 +030013openrc_templ = """#!/bin/sh
14export LC_ALL=C
15export OS_NO_CACHE='true'
16export OS_TENANT_NAME='{tenant}'
17export OS_USERNAME='{name}'
18export OS_PASSWORD='{passwd}'
19export OS_AUTH_URL='{auth_url}'
20export OS_AUTH_STRATEGY='keystone'
21export OS_REGION_NAME='RegionOne'
22export CINDER_ENDPOINT_TYPE='publicURL'
23export GLANCE_ENDPOINT_TYPE='publicURL'
24export KEYSTONE_ENDPOINT_TYPE='publicURL'
25export NOVA_ENDPOINT_TYPE='publicURL'
26export NEUTRON_ENDPOINT_TYPE='publicURL'
27"""
28
29
koder aka kdanilove87ae652015-04-20 02:14:35 +030030def discover(ctx, discover, clusters_info, var_dir, discover_nodes=True):
Yulia Portnova0e64ea22015-03-20 17:27:22 +020031 nodes_to_run = []
koder aka kdanilovcff7b2e2015-04-18 20:48:15 +030032 clean_data = None
koder aka kdanilovda45e882015-04-06 02:24:42 +030033 for cluster in discover:
koder aka kdanilove87ae652015-04-20 02:14:35 +030034 if cluster == "openstack" and not discover_nodes:
35 logger.warning("Skip openstack cluster discovery")
36 elif cluster == "openstack" and discover_nodes:
koder aka kdanilovda45e882015-04-06 02:24:42 +030037 cluster_info = clusters_info["openstack"]
koder aka kdanilove06762a2015-03-22 23:32:09 +020038 conn = cluster_info['connection']
39 user, passwd, tenant = parse_creds(conn['creds'])
40
41 auth_data = dict(
42 auth_url=conn['auth_url'],
43 username=user,
44 api_key=passwd,
45 project_id=tenant)
46
Yulia Portnova0e64ea22015-03-20 17:27:22 +020047 if not conn:
48 logger.error("No connection provided for %s. Skipping"
49 % cluster)
50 continue
koder aka kdanilove06762a2015-03-22 23:32:09 +020051
Yulia Portnova0e64ea22015-03-20 17:27:22 +020052 logger.debug("Discovering openstack nodes "
53 "with connection details: %r" %
54 conn)
55
koder aka kdanilove06762a2015-03-22 23:32:09 +020056 os_nodes = openstack.discover_openstack_nodes(auth_data,
57 cluster_info)
58 nodes_to_run.extend(os_nodes)
59
koder aka kdanilovcee43342015-04-14 22:52:53 +030060 elif cluster == "fuel":
koder aka kdanilove87ae652015-04-20 02:14:35 +030061 res = fuel.discover_fuel_nodes(clusters_info['fuel'],
62 var_dir,
63 discover_nodes)
koder aka kdanilovcff7b2e2015-04-18 20:48:15 +030064 nodes, clean_data, openrc_dict = res
gstepanov59d80f72015-04-10 17:24:27 +030065
koder aka kdanilovcee43342015-04-14 22:52:53 +030066 ctx.fuel_openstack_creds = {'name': openrc_dict['username'],
67 'passwd': openrc_dict['password'],
68 'tenant': openrc_dict['tenant_name'],
69 'auth_url': openrc_dict['os_auth_url']}
gstepanov59d80f72015-04-10 17:24:27 +030070
koder aka kdanilov168f6092015-04-19 02:33:38 +030071 env_name = clusters_info['fuel']['openstack_env']
72 env_f_name = env_name
73 for char in "-+ {}()[]":
74 env_f_name = env_f_name.replace(char, '_')
75
76 fuel_openrc_fname = os.path.join(var_dir,
77 env_f_name + "_openrc")
koder aka kdanilove87ae652015-04-20 02:14:35 +030078
koder aka kdanilov168f6092015-04-19 02:33:38 +030079 with open(fuel_openrc_fname, "w") as fd:
80 fd.write(openrc_templ.format(**ctx.fuel_openstack_creds))
koder aka kdanilove87ae652015-04-20 02:14:35 +030081
koder aka kdanilov168f6092015-04-19 02:33:38 +030082 msg = "Openrc for cluster {0} saves into {1}"
83 logger.debug(msg.format(env_name, fuel_openrc_fname))
gstepanov59d80f72015-04-10 17:24:27 +030084 nodes_to_run.extend(nodes)
koder aka kdanilovda45e882015-04-06 02:24:42 +030085
86 elif cluster == "ceph":
koder aka kdanilove87ae652015-04-20 02:14:35 +030087 if discover_nodes:
88 cluster_info = clusters_info["ceph"]
89 nodes_to_run.extend(ceph.discover_ceph_nodes(cluster_info))
90 else:
91 logger.warning("Skip ceph cluster discovery")
koder aka kdanilovda45e882015-04-06 02:24:42 +030092 else:
93 msg_templ = "Unknown cluster type in 'discover' parameter: {0!r}"
94 raise ValueError(msg_templ.format(cluster))
koder aka kdanilov2c473092015-03-29 17:12:13 +030095
koder aka kdanilovcff7b2e2015-04-18 20:48:15 +030096 return nodes_to_run, clean_data
97
98
99def undiscover(clean_data):
100 if clean_data is not None:
101 fuel.clean_fuel_port_forwarding(clean_data)