| # Copyright (c) 2019 AT&T Intellectual Property. |
| # Copyright (c) 2018-2022 Nokia. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| |
| # |
| # This source code is part of the near-RT RIC (RAN Intelligent Controller) |
| # platform project (RICP). |
| # |
| |
| |
| """The module provides implementation of Shared Data Layer (SDL) configurability.""" |
| import os |
| from enum import Enum |
| from collections import namedtuple |
| |
| |
| class DbBackendType(Enum): |
| """Enumeration class of supported SDL database backend types.""" |
| REDIS = 1 |
| FAKE_DICT = 2 |
| |
| |
| class _Configuration(): |
| """This class implements Shared Data Layer (SDL) configurability.""" |
| Params = namedtuple('Params', ['db_host', 'db_ports', 'db_sentinel_ports', |
| 'db_sentinel_master_names', |
| 'db_cluster_addrs', 'db_type']) |
| |
| def __init__(self, fake_db_backend): |
| self.params = self._read_configuration(fake_db_backend) |
| |
| def __str__(self): |
| return str( |
| { |
| "DB host": self.params.db_host, |
| "DB ports": self.params.db_ports, |
| "DB master sentinels": self.params.db_sentinel_master_names, |
| "DB sentinel ports": self.params.db_sentinel_ports, |
| "DB cluster addresses": self.params.db_cluster_addrs, |
| "DB type": self.params.db_type.name, |
| } |
| ) |
| |
| def get_params(self): |
| """Return SDL configuration.""" |
| return self.params |
| |
| @classmethod |
| def _read_configuration(cls, fake_db_backend): |
| backend_type = DbBackendType.REDIS |
| if fake_db_backend: |
| if fake_db_backend.lower() != 'dict': |
| msg = ("Configuration error: " |
| "SDL instance was initiated with wrong " |
| "'fake_db_backend' argument value: {}. " |
| "Value 'dict' is only supported.". |
| format(fake_db_backend)) |
| raise ValueError(msg) |
| |
| backend_type = DbBackendType.FAKE_DICT |
| host = os.getenv('DBAAS_SERVICE_HOST', "") |
| |
| port_env = os.getenv('DBAAS_SERVICE_PORT') |
| ports = port_env.split(",") if port_env is not None else list() |
| |
| sentinel_port_env = os.getenv('DBAAS_SERVICE_SENTINEL_PORT') |
| sentinel_ports = sentinel_port_env.split(",") if sentinel_port_env is not None else list() |
| |
| sentinel_name_env = os.getenv('DBAAS_MASTER_NAME') |
| sentinel_names = sentinel_name_env.split(",") if sentinel_name_env is not None else list() |
| |
| addr_env = os.getenv('DBAAS_CLUSTER_ADDR_LIST') |
| addrs = addr_env.split(",") if addr_env is not None else list() |
| |
| if len(addrs) == 0 and len(host) > 0: |
| addrs.append(host) |
| |
| addrs, ports, sentinel_ports, sentinel_names = cls._complete_configuration( |
| addrs, ports, sentinel_ports, sentinel_names) |
| |
| return _Configuration.Params(db_host=host, |
| db_ports=ports, |
| db_sentinel_ports=sentinel_ports, |
| db_sentinel_master_names=sentinel_names, |
| db_cluster_addrs=addrs, |
| db_type=backend_type) |
| |
| @classmethod |
| def _complete_configuration(cls, addrs, ports, sentinel_ports, sentinel_names): |
| if len(sentinel_ports) == 0: |
| if len(addrs) > len(ports) and len(ports) > 0: |
| for i in range(len(ports), len(addrs)): |
| ports.append(ports[i - 1]) |
| else: |
| if len(addrs) > len(sentinel_ports): |
| for i in range(len(sentinel_ports), len(addrs)): |
| sentinel_ports.append(sentinel_ports[i - 1]) |
| if len(addrs) > len(sentinel_names) and len(sentinel_names) > 0: |
| for i in range(len(sentinel_names), len(addrs)): |
| sentinel_names.append(sentinel_names[i - 1]) |
| return addrs, ports, sentinel_ports, sentinel_names |
| |
| @classmethod |
| def get_event_separator(cls): |
| return "___" |