Source code for mailman_pgp.config.config
# Copyright (C) 2017 Jan Jancar
#
# This file is a part of the Mailman PGP plugin.
#
# This program is free software; you can redistribute it and/or modify it under
# the terms of the GNU General Public License as published by the Free
# Software Foundation, either version 3 of the License, or (at your option)
# any later version.
#
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
# more details.
#
# You should have received a copy of the GNU General Public License along with
# this program. If not, see <http://www.gnu.org/licenses/>.
"""Mailman PGP configuration module."""
import logging
from configparser import ConfigParser
from mailman.config import config as mailman_config
from mailman.utilities.modules import expand_path
from pkg_resources import resource_string
from public.public import public
from mailman_pgp.config.converter import ConfigConverter
from mailman_pgp.config.validator import ConfigValidator
log = logging.getLogger('mailman.plugin.pgp.config')
@public
[docs]class Config(ConfigParser):
"""A ConfigParser with a name."""
def __init__(self):
super().__init__()
self.name = None
self.dict = None
schema = resource_string('mailman_pgp.config',
'schema.cfg').decode('utf-8')
self.validator = ConfigValidator(schema)
self.converter = ConfigConverter(schema)
[docs] def load(self, name):
"""
Load the plugin configuration, and set our name.
:param name: The name to set/load configuration for.
:type name: str
"""
self.name = name
self.read(expand_path(
dict(mailman_config.plugin_configs)[self.name].configuration))
log.debug('Config loaded.')
[docs] def validate(self):
try:
self.validator.validate(self)
except ValueError:
log.exception('Config did not validate.')
raise
log.debug('Config validated.')
[docs] def convert(self):
self.dict = self.converter.convert(self)
log.debug('Config converted.')
[docs] def get_value(self, section, option):
return self.dict[section][option]
[docs] def set(self, section, option, value=None):
self.dict[section][option] = self.converter.converter(section, option)(
value)
return super().set(section, option, value)