tools.win_pg_dump_controller

Yohn Y. 2022-06-13 Parent:7c93b0305522

5:7de4fb4ef2f5 Go to Latest

tools.win_pg_dump_controller/win_pg_dump_controller/config.py

. Не тот порт по умолчанию для postgres

History
awgur@0 1 # coding: utf-8
awgur@0 2 from configparser import ConfigParser, SectionProxy
awgur@0 3 from sys import argv
awgur@0 4 from os.path import isdir
awgur@0 5 from typing import Optional, Iterable
awgur@0 6
awgur@0 7
awgur@0 8 from .error import Error
awgur@0 9
awgur@0 10
awgur@0 11 class ConfigError(Error):
awgur@0 12 pass
awgur@0 13
awgur@0 14
awgur@0 15 COMMON_SECTION = 'common'
awgur@0 16 MAIN = 'main'
awgur@2 17 SMTP = 'smtp'
awgur@0 18 DEFAULT_PG_PORT = 5432
awgur@0 19
awgur@0 20
awgur@0 21 class DBTask(object):
awgur@0 22 def __init__(self, task_name: str, host_name: str, db_name: str, user_name: str, passwd: Optional[str],
awgur@0 23 dst_dir: str, port: int = DEFAULT_PG_PORT):
awgur@0 24 self.host_name = host_name
awgur@0 25 self.db_name = db_name
awgur@0 26 self.user_name = user_name
awgur@0 27 self.passwd = passwd
awgur@0 28 self.dst_dir = dst_dir
awgur@0 29 self.name = task_name
awgur@0 30 self.port = port
awgur@0 31
awgur@0 32 if not (self.db_name or self.user_name or self.dst_dir or self.host_name):
awgur@0 33 raise ConfigError(f'Some important config parameters not set: '
awgur@0 34 f'db_name="{db_name}" '
awgur@0 35 f'user_name="{user_name}" '
awgur@0 36 f'dst_dir="{dst_dir}" '
awgur@0 37 f'host_name="{host_name}"')
awgur@0 38
awgur@0 39
awgur@0 40 class CommonTaskDescription(object):
awgur@0 41 def __init__(self, host_name: Optional[str], user_name: Optional[str],
awgur@0 42 passwd: Optional[str], dst_dir: Optional[str], port: int = DEFAULT_PG_PORT):
awgur@0 43 self.user_name = user_name
awgur@0 44 self.passwd = passwd
awgur@0 45 self.dst_dir = dst_dir
awgur@0 46 self.host_name = host_name
awgur@0 47 self.port = port
awgur@0 48
awgur@0 49 def parse_section(self, config_section: SectionProxy) -> DBTask:
awgur@0 50 db_name = config_section.get('db_name')
awgur@0 51 user_name = config_section.get('user_name', self.user_name)
awgur@0 52 passwd = config_section.get('passwd', self.passwd)
awgur@0 53 dst_dir = config_section.get('dst_dir', self.dst_dir)
awgur@0 54 host_name = config_section.get('host_name', self.host_name)
awgur@0 55 port = config_section.getint('port', self.port)
awgur@0 56
awgur@0 57 if not isdir(dst_dir):
awgur@0 58 raise ConfigError(f'Destionation directory not exists for "{config_section.name}": {dst_dir}')
awgur@0 59
awgur@0 60 return DBTask(task_name=config_section.name, host_name=host_name, db_name=db_name,
awgur@0 61 user_name=user_name, passwd=passwd, port=port, dst_dir=dst_dir)
awgur@0 62
awgur@0 63 @classmethod
awgur@0 64 def parse_config(cls, config: ConfigParser) -> Iterable[DBTask]:
awgur@0 65 if not config.has_section(COMMON_SECTION):
awgur@0 66 tmpl = cls(host_name=None, user_name=None, passwd=None, dst_dir=None)
awgur@0 67
awgur@0 68 else:
awgur@0 69 _section = config['common']
awgur@0 70 host_name = _section.get('host_name', '127.0.0.1')
awgur@0 71 user_name = _section.get('user_name')
awgur@0 72 passwd = _section.get('passwd')
awgur@0 73 dst_dir = _section.get('dst_dir')
awgur@0 74 port = _section.getint('port', DEFAULT_PG_PORT)
awgur@0 75
awgur@0 76 tmpl = cls(host_name=host_name, user_name=user_name, passwd=passwd, dst_dir=dst_dir, port=port)
awgur@0 77
awgur@2 78 for _section in filter(lambda x: x not in (COMMON_SECTION, MAIN, SMTP), config.sections()):
awgur@0 79 yield tmpl.parse_section(config[_section])
awgur@0 80
awgur@0 81
awgur@0 82 class Config(object):
awgur@0 83 def __init__(self):
awgur@0 84 try:
awgur@0 85 config_file = argv[1]
awgur@0 86 except IndexError:
awgur@0 87 raise ConfigError(f'No config file specified')
awgur@0 88
awgur@0 89 _config = ConfigParser()
awgur@0 90 _config.read(config_file)
awgur@0 91
awgur@0 92 _main_section = _config[MAIN]
awgur@0 93 self.pg_bin_path = _main_section.get('pg_bin_path')
awgur@0 94 self.pg_dump_flags = _main_section.get('pg_dump_flags', '')
awgur@0 95 self.log_dir = _main_section.get('log_dir')
awgur@0 96 self.teir1_days = _main_section.getint('teir1_days', 7)
awgur@0 97 self.teir2_copies_interval = _main_section.getint('teir2_copies_interval', 7)
awgur@0 98 self.tier2_store_days = _main_section.getint('tier2_store_days', 30)
awgur@0 99 self.keep_logs_days = _main_section.getint('keep_logs_days', 30)
awgur@0 100
awgur@2 101 self.smtp_server = None
awgur@2 102 self.mail_from = None
awgur@2 103 self.mail_to = None
awgur@2 104 self.smtp_port = None
awgur@2 105
awgur@2 106 if _config.has_section(SMTP):
awgur@2 107 _smtp_section = _config[SMTP]
awgur@2 108 self.smtp_server = _smtp_section.get('smtp server')
awgur@2 109 self.mail_from = _smtp_section.get('mail from')
awgur@2 110 self.mail_to = _smtp_section.get('mail to', fallback='root')
awgur@2 111 self.smtp_port = _smtp_section.getint('smtp port', fallback=25)
awgur@2 112
awgur@0 113 if not isdir(self.pg_bin_path):
awgur@0 114 raise ConfigError(f'No valid directory with binnary files of PostgreSQL is set: {self.pg_bin_path}')
awgur@0 115
awgur@0 116 self.tasks = list(CommonTaskDescription.parse_config(_config))