# # 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 KeystoneApiProxyHelm(openstack.OpenstackBaseHelm): """Class to encapsulate helm operations for the keystone api proxy chart""" CHART = app_constants.HELM_CHART_KEYSTONE_API_PROXY SERVICE_NAME = app_constants.HELM_CHART_KEYSTONE_API_PROXY DCORCH_SERVICE_NAME = 'dcorch' 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(KeystoneApiProxyHelm, self)._is_enabled( app_name, chart_name, namespace) if enabled and (self._distributed_cloud_role() != constants.DISTRIBUTED_CLOUD_ROLE_SYSTEMCONTROLLER): enabled = False return enabled def execute_manifest_updates(self, operator): # This chart group is not included by default in the manifest. Insert as # needed. if self._is_enabled(operator.APP, self.CHART, common.HELM_NS_OPENSTACK): operator.manifest_chart_groups_insert( operator.ARMADA_MANIFEST, operator.CHART_GROUPS_LUT[self.CHART]) def get_overrides(self, namespace=None): overrides = { common.HELM_NS_OPENSTACK: { 'pod': { 'user': { 'keystone_api_proxy': { 'uid': 0 } } }, 'conf': { 'keystone_api_proxy': { 'DEFAULT': { 'transport_url': self._get_transport_url() }, 'database': { 'connection': self._get_database_connection() }, 'identity': { 'remote_host': self._get_keystone_endpoint(), } } }, '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): return { 'identity': { 'auth': self._get_endpoints_identity_overrides( self.SERVICE_NAME, []) }, 'keystone_api_proxy': { 'host_fqdn_override': self._get_endpoints_host_fqdn_overrides( app_constants.HELM_CHART_KEYSTONE_API_PROXY), 'port': self._get_endpoints_port_api_public_overrides(), 'scheme': self._get_endpoints_scheme_public_overrides(), } } def _get_transport_url(self): host_url = self._format_url_address(self._get_management_address()) auth_password = self._get_keyring_password('amqp', 'rabbit') transport_url = "rabbit://guest:%s@%s:5672" % (auth_password, host_url) return transport_url def _get_database_connection(self): host_url = self._format_url_address(self._get_management_address()) auth_password = self._get_keyring_password( self.DCORCH_SERVICE_NAME, 'database') connection = "postgresql+psycopg2://admin-dcorch:%s@%s/dcorch" %\ (auth_password, host_url) return connection def _get_keystone_endpoint(self): return 'keystone-api.openstack.svc.cluster.local'