관리-도구
편집 파일: v1import.py
# coding=utf-8 # # Copyright © Cloud Linux GmbH & Cloud Linux Software, Inc 2010-2019 All Rights Reserved # # Licensed under CLOUD LINUX LICENSE AGREEMENT # http://cloudlinux.com/docs/LICENSE.TXT import os CONFIG_PATH_v1 = '/etc/sysconfig/lvestats' CONFIG_PATH_v2 = '/etc/sysconfig/lvestats2' NOTIFY_PATH_v1 = '/etc/sysconfig/cloudlinux-notify' NOTIFY_PATH_v2 = '/etc/sysconfig/lvestats.config/StatsNotifier.cfg' IMPORT_STATUS_FILE = '/usr/share/lve-stats/utils/import-settings-status' V1_DB_MIIGRATOR_CONFIG = '/etc/sysconfig/lvestats.config/V1DBMigrator.cfg' V1_SQLITE_DB = 'sqlite:////var/lve/lveinfo.db' V1_DB_MIIGRATOR_PLUGIN_SRC = '/usr/share/lve-stats/plugins.other/v1_db_migrator.py' V1_DB_MIIGRATOR_PLUGIN_LINK = '/usr/share/lve-stats/plugins/v1_db_migrator.py' V1_KEY = 'v1_connect_string' def init_v1_db_migrator(config): if V1_KEY not in config: print('Cannot find db info to enable migration plugin') return if 'server_id' not in config: config['server_id'] = 'localhost' with open(V1_DB_MIIGRATOR_CONFIG, 'w', encoding='utf-8') as cfg: cfg.write(f'v1_server_id={config["server_id"]}\nv1_connect_string={config[V1_KEY]}\n') try: if not os.path.lexists(V1_DB_MIIGRATOR_PLUGIN_LINK): os.symlink(V1_DB_MIIGRATOR_PLUGIN_SRC, V1_DB_MIIGRATOR_PLUGIN_LINK) except (IOError, OSError) as e: print(f"Unable to enable db migration plugin: {e}, continue: ") def get_import_status(): if os.path.exists(IMPORT_STATUS_FILE): with open(IMPORT_STATUS_FILE, 'r', encoding='utf-8') as f: v = f.read() try: return int(v) except ValueError as e: raise RuntimeError(f'Invalid status format for file {IMPORT_STATUS_FILE}') from e else: return 0 def set_import_status(flag): with open(IMPORT_STATUS_FILE, 'w', encoding='utf-8') as f: f.write(f'{flag}') def get_config_path(path): if os.path.exists(path): return path elif os.path.exists(path + '.rpmsave'): return path + '.rpmsave' return '' def get_connection_string(lvestats_config): if 'db_type' in lvestats_config: if 'connect_string' in lvestats_config and lvestats_config['db_type'] in ('mysql', 'postgresql'): connect_string = lvestats_config['connect_string'].split(':') host = connect_string[0] database = connect_string[1] user = connect_string[2] password = connect_string[3] lvestats_config['connect_string'] = f"{user}:{password}@{host}/{database}" lvestats_config[V1_KEY] = f"{lvestats_config['db_type']}://{lvestats_config['connect_string']}" elif lvestats_config['db_type'] == 'sqlite': lvestats_config[V1_KEY] = V1_SQLITE_DB