nuvolaris/nuvolaris_metadata.py (57 lines of code) (raw):

# Licensed to the Apache Software Foundation (ASF) under one # or more contributor license agreements. See the NOTICE file # distributed with this work for additional information # regarding copyright ownership. The ASF licenses this file # to you 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. # import json import logging from datetime import datetime import nuvolaris.bcrypt_util as bu import nuvolaris.config as cfg import nuvolaris.util as util class NuvolarisMetadata: _data = {} def __init__(self): password = cfg.get('nuvolaris.password') or "nuvpassw0rd" salted_password = bu.hash_password(password) self._data = { "login":"nuvolaris", "password":salted_password, "password_timestamp": datetime.now().isoformat(), "email":cfg.get('nuvolaris.email') or "nuvolaris@nuvolaris.io", "metadata":[] } self._configure_from_cm() def _store_safely_from_cm(self,metadata_key,json_path): try: value = util.get_value_from_config_map("nuvolaris", json_path) if value: self.add_metadata(metadata_key, value) except Exception as e: logging.warn(e) def _configure_from_cm(self): """ Populates the internal metadata starting from the cm/config map """ self.add_metadata("AUTH", cfg.get('openwhisk.namespaces.nuvolaris')) self._store_safely_from_cm("MONGODB_URL", '{.metadata.annotations.mongodb_url}') self._store_safely_from_cm("POSTGRES_DATABASE", '{.metadata.annotations.postgres_database}') self._store_safely_from_cm("POSTGRES_HOST", '{.metadata.annotations.postgres_host}') self._store_safely_from_cm("POSTGRES_PASSWORD", '{.metadata.annotations.postgres_password}') self._store_safely_from_cm("POSTGRES_PORT", '{.metadata.annotations.postgres_port}') self._store_safely_from_cm("POSTGRES_URL", '{.metadata.annotations.postgres_url}') self._store_safely_from_cm("POSTGRES_USERNAME", '{.metadata.annotations.postgres_username}') self._store_safely_from_cm("REDIS_PREFIX", '{.metadata.annotations.redis_prefix}') self._store_safely_from_cm("REDIS_URL", '{.metadata.annotations.redis_url}') self._store_safely_from_cm("S3_HOST", '{.metadata.annotations.s3_host}') self._store_safely_from_cm("S3_PORT", '{.metadata.annotations.s3_port}') self._store_safely_from_cm("S3_SECRET_KEY", '{.metadata.annotations.s3_secret_key}') self._store_safely_from_cm("S3_ACCESS_KEY", '{.metadata.annotations.s3_access_key}') self._store_safely_from_cm("S3_BUCKET_STATIC", '{.metadata.annotations.s3_bucket_static}') self._store_safely_from_cm("S3_BUCKET_DATA", '{.metadata.annotations.s3_bucket_data}') self._store_safely_from_cm("S3_PROVIDER", '{.metadata.annotations.s3_provider}') self._store_safely_from_cm("S3_API_URL", '{.metadata.annotations.s3_api_url}') self._store_safely_from_cm("S3_CONSOLE_URL", '{.metadata.annotations.s3_console_url}') self._store_safely_from_cm("MILVUS_HOST", '{.metadata.annotations.milvus_host}') self._store_safely_from_cm("MILVUS_PORT", '{.metadata.annotations.milvus_port}') self._store_safely_from_cm("MILVUS_TOKEN", '{.metadata.annotations.milvus_token}') self._store_safely_from_cm("MILVUS_DB_NAME", '{.metadata.annotations.milvus_db_name}') def dump(self): logging.debug(json.dumps(self._data)) def add_metadata(self, key: str, value: str): """ append an entry to the metadata with this structure {"key":key, "value":value} """ logging.debug(f"adding ({key}={value})") self._data['metadata'].append({"key":key, "value":value}) def get_metadata(self): return self._data