174 lines
5.1 KiB
Python
174 lines
5.1 KiB
Python
#
|
|
# Copyright (c) 2018 Wind River Systems, Inc.
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
|
|
from sysinv.common import constants
|
|
from sysinv.common import exception
|
|
from sysinv.openstack.common import log as logging
|
|
|
|
from sysinv.helm import common
|
|
from sysinv.helm import openstack
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
# Info used in the Glance Helm chart.
|
|
RBD_STORE_USER = 'images'
|
|
|
|
|
|
class GlanceHelm(openstack.OpenstackBaseHelm):
|
|
"""Class to encapsulate helm operations for the glance chart"""
|
|
|
|
CHART = constants.HELM_CHART_GLANCE
|
|
SUPPORTED_NAMESPACES = [
|
|
common.HELM_NS_OPENSTACK
|
|
]
|
|
|
|
SERVICE_NAME = 'glance'
|
|
SERVICE_TYPE = 'image'
|
|
AUTH_USERS = ['glance']
|
|
|
|
def get_namespaces(self):
|
|
return self.SUPPORTED_NAMESPACES
|
|
|
|
def get_overrides(self, namespace=None):
|
|
overrides = {
|
|
common.HELM_NS_OPENSTACK: {
|
|
'pod': self._get_pod_overrides(),
|
|
'endpoints': self._get_endpoints_overrides(),
|
|
'storage': self._get_storage_overrides(),
|
|
'conf': self._get_conf_overrides(),
|
|
'images': self._get_images_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_images_overrides(self):
|
|
heat_image = self._operator.chart_operators[
|
|
constants.HELM_CHART_HEAT].docker_image
|
|
return {
|
|
'tags': {
|
|
'bootstrap': heat_image,
|
|
'db_drop': heat_image,
|
|
'db_init': heat_image,
|
|
'glance_api': self.docker_image,
|
|
'glance_db_sync': self.docker_image,
|
|
'glance_registry': self.docker_image,
|
|
'ks_endpoints': heat_image,
|
|
'ks_service': heat_image,
|
|
'ks_user': heat_image,
|
|
}
|
|
}
|
|
|
|
def _get_pod_overrides(self):
|
|
replicas_count = 1
|
|
ceph_backend = self._get_primary_ceph_backend()
|
|
if ceph_backend:
|
|
replicas_count = self._num_controllers()
|
|
|
|
return {
|
|
'replicas': {
|
|
'api': replicas_count,
|
|
}
|
|
}
|
|
|
|
def _get_endpoints_overrides(self):
|
|
return {
|
|
'identity': {
|
|
'auth': self._get_endpoints_identity_overrides(
|
|
self.SERVICE_NAME, self.AUTH_USERS),
|
|
},
|
|
'oslo_cache': {
|
|
'auth': {
|
|
'memcached_secret_key':
|
|
self._get_common_password('auth_memcache_key')
|
|
}
|
|
},
|
|
'oslo_messaging': {
|
|
'auth': self._get_endpoints_oslo_messaging_overrides(
|
|
self.SERVICE_NAME, self.AUTH_USERS)
|
|
},
|
|
'oslo_db': {
|
|
'auth': self._get_endpoints_oslo_db_overrides(
|
|
self.SERVICE_NAME, self.AUTH_USERS)
|
|
},
|
|
|
|
}
|
|
|
|
def _get_storage_overrides(self):
|
|
ceph_backend = self._get_primary_ceph_backend()
|
|
|
|
if not ceph_backend:
|
|
return 'pvc'
|
|
|
|
return constants.GLANCE_BACKEND_RBD # radosgw| rbd | swift | pvc
|
|
|
|
def _get_ceph_overrides(self):
|
|
conf_ceph = {
|
|
'admin_keyring': self._get_ceph_password(
|
|
self.SERVICE_NAME, 'admin_keyring'
|
|
),
|
|
'monitors': self._get_formatted_ceph_monitor_ips()
|
|
}
|
|
|
|
return conf_ceph
|
|
|
|
def _get_conf_overrides(self):
|
|
ceph_backend = self._get_primary_ceph_backend()
|
|
if not ceph_backend:
|
|
rbd_store_pool = ""
|
|
rbd_store_user = ""
|
|
else:
|
|
rbd_store_pool = constants.CEPH_POOL_IMAGES_NAME
|
|
rbd_store_user = RBD_STORE_USER
|
|
|
|
conf = {
|
|
'glance': {
|
|
'DEFAULT': {
|
|
'graceful_shutdown': True,
|
|
'show_image_direct_url': True,
|
|
},
|
|
'glance_store': {
|
|
'filesystem_store_datadir': constants.GLANCE_IMAGE_PATH,
|
|
'rbd_store_pool': rbd_store_pool,
|
|
'rbd_store_user': rbd_store_user,
|
|
}
|
|
}
|
|
}
|
|
|
|
if ceph_backend:
|
|
conf['ceph'] = self._get_ceph_overrides()
|
|
|
|
return conf
|
|
|
|
def _get_primary_ceph_backend(self):
|
|
try:
|
|
backend = self.dbapi.storage_backend_get_by_name(
|
|
constants.SB_DEFAULT_NAMES[constants.SB_TYPE_CEPH])
|
|
except exception.StorageBackendNotFoundByName:
|
|
backend = None
|
|
pass
|
|
|
|
return backend
|
|
|
|
def get_region_name(self):
|
|
return self._get_service_region_name(self.SERVICE_NAME)
|
|
|
|
def get_service_name(self):
|
|
return self._get_configured_service_name(self.SERVICE_NAME)
|
|
|
|
def get_service_type(self):
|
|
service_type = self._get_configured_service_type(self.SERVICE_NAME)
|
|
if service_type is None:
|
|
return self.SERVICE_TYPE
|
|
else:
|
|
return service_type
|