169 lines
6.2 KiB
Python
169 lines
6.2 KiB
Python
#
|
|
# Copyright (c) 2019-2020 Wind River Systems, Inc.
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
|
|
from k8sapp_openstack.common import constants as app_constants
|
|
from k8sapp_openstack.helm import openstack
|
|
|
|
from sysinv.common import constants
|
|
from sysinv.common import exception
|
|
|
|
from sysinv.helm import common
|
|
|
|
|
|
class IronicHelm(openstack.OpenstackBaseHelm):
|
|
"""Class to encapsulate helm operations for the ironic chart"""
|
|
|
|
CHART = app_constants.HELM_CHART_IRONIC
|
|
|
|
SERVICE_NAME = app_constants.HELM_CHART_IRONIC
|
|
SERVICE_USERS = ['glance']
|
|
AUTH_USERS = ['ironic']
|
|
|
|
def _is_enabled(self, app_name, chart_name, namespace):
|
|
# First, see if this chart is enabled by the user then adjust based on
|
|
# system conditions
|
|
enabled = super(IronicHelm, self)._is_enabled(app_name,
|
|
chart_name, namespace)
|
|
if enabled and self._num_controllers() < 2:
|
|
enabled = False
|
|
return enabled
|
|
|
|
def execute_manifest_updates(self, operator):
|
|
# On application load, this chart is disabled in the metadata. Insert as
|
|
# needed.
|
|
if self._is_enabled(operator.APP,
|
|
self.CHART, common.HELM_NS_OPENSTACK):
|
|
operator.chart_group_chart_insert(
|
|
operator.CHART_GROUPS_LUT[self.CHART],
|
|
operator.CHARTS_LUT[self.CHART])
|
|
|
|
def get_overrides(self, namespace=None):
|
|
overrides = {
|
|
common.HELM_NS_OPENSTACK: {
|
|
'pod': {
|
|
'replicas': {
|
|
'api': self._num_provisioned_controllers(),
|
|
'conductor': self._num_provisioned_controllers()
|
|
}
|
|
},
|
|
'network': self._get_network_overrides(),
|
|
'endpoints': self._get_endpoints_overrides()
|
|
}
|
|
}
|
|
|
|
if namespace in self.SUPPORTED_NAMESPACES:
|
|
return overrides[namespace]
|
|
elif namespace:
|
|
raise exception.InvalidHelmNamespace(chart=self.CHART,
|
|
namespace=namespace)
|
|
else:
|
|
return overrides
|
|
|
|
def _get_endpoints_overrides(self):
|
|
overrides = {
|
|
'identity': {
|
|
'auth': self._get_endpoints_identity_overrides(
|
|
self.SERVICE_NAME, self.AUTH_USERS),
|
|
},
|
|
'oslo_cache': {
|
|
'auth': {
|
|
'memcache_secret_key':
|
|
self._get_common_password('auth_memcache_key')
|
|
}
|
|
},
|
|
'oslo_db': {
|
|
'auth': self._get_endpoints_oslo_db_overrides(
|
|
self.SERVICE_NAME, self.AUTH_USERS)
|
|
},
|
|
'oslo_messaging': {
|
|
'auth': self._get_endpoints_oslo_messaging_overrides(
|
|
self.SERVICE_NAME, self.AUTH_USERS)
|
|
},
|
|
}
|
|
|
|
# Service user passwords already exist in other chart overrides
|
|
for user in self.SERVICE_USERS:
|
|
overrides['identity']['auth'].update({
|
|
user: {
|
|
'region_name': self._region_name(),
|
|
'password': self._get_or_generate_password(
|
|
user, common.HELM_NS_OPENSTACK, user)
|
|
}
|
|
})
|
|
|
|
return overrides
|
|
|
|
def _get_interface_port_name(self, iface):
|
|
"""
|
|
Determine the port name of the underlying device.
|
|
"""
|
|
assert iface['iftype'] == constants.INTERFACE_TYPE_ETHERNET
|
|
port = self.dbapi.port_get_by_interface(iface.id)
|
|
if port:
|
|
return port[0]['name']
|
|
|
|
def _get_ironic_port(self):
|
|
ironic_port = ''
|
|
if self.dbapi is None:
|
|
return ironic_port
|
|
# find the first interface with ironic network type
|
|
interfaces = self.dbapi.iinterface_get_all()
|
|
for iface in interfaces:
|
|
for net_type in iface.networktypelist:
|
|
if net_type == constants.NETWORK_TYPE_IRONIC:
|
|
ironic_port = self._get_interface_port_name(iface)
|
|
break
|
|
return ironic_port
|
|
|
|
def _get_ironic_addrpool(self):
|
|
ironic_addrpool = {}
|
|
if self.dbapi is None:
|
|
return ironic_addrpool
|
|
networks = self.dbapi.networks_get_by_type(
|
|
constants.NETWORK_TYPE_IRONIC)
|
|
for network in networks:
|
|
addrpool = self.dbapi.address_pool_get(network.pool_uuid)
|
|
if addrpool:
|
|
ironic_addrpool['cidr'] = str(addrpool.network) + \
|
|
'/' + str(addrpool.prefix)
|
|
ironic_addrpool['gateway'] = str(addrpool.gateway_address)
|
|
ironic_addrpool['start'] = str(addrpool.ranges[0][0])
|
|
ironic_addrpool['end'] = str(addrpool.ranges[0][1])
|
|
break
|
|
return ironic_addrpool
|
|
|
|
# retrieve ironic network settings from address pools,
|
|
# ironic ethernet port name from interfaces,
|
|
# and ironic provider network from data networks.
|
|
#
|
|
# NOTE: Different ethernet port name for ironic conductor not supported.
|
|
# Currently the name of ironic port should be the same on each
|
|
# controllers to support HA, otherwise the initialization
|
|
# of ironic-conductor-pxe would be failed. It's a limitation
|
|
# from openstack-helm/ironic that ironic conductors use same
|
|
# configuration file for init.
|
|
def _get_network_overrides(self):
|
|
ironic_addrpool = self._get_ironic_addrpool()
|
|
gateway = ironic_addrpool.get('gateway', '')
|
|
cidr = ironic_addrpool.get('cidr', '')
|
|
start = ironic_addrpool.get('start', '')
|
|
end = ironic_addrpool.get('end', '')
|
|
|
|
overrides = {
|
|
'pxe': {
|
|
'device': str(self._get_ironic_port()),
|
|
# User can define it's own tenant network name by
|
|
# 'system helm-override-update' to update this value
|
|
'neutron_provider_network': 'ironic',
|
|
'neutron_subnet_gateway': str(gateway),
|
|
'neutron_subnet_cidr': str(cidr),
|
|
'neutron_subnet_alloc_start': str(start),
|
|
'neutron_subnet_alloc_end': str(end)
|
|
},
|
|
}
|
|
|
|
return overrides
|