Passed
Pull Request — master (#122)
by Juan José
02:21 queued 59s
created

ospd.config   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 48
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 20
dl 0
loc 48
rs 10
c 0
b 0
f 0
wmc 5

3 Methods

Rating   Name   Duplication   Size   Complexity  
A Config.__init__() 0 4 1
A Config.load() 0 12 3
A Config.defaults() 0 2 1
1
# -*- coding: utf-8 -*-
2
# Copyright (C) 2019 Greenbone Networks GmbH
3
#
4
# SPDX-License-Identifier: GPL-3.0-or-later
5
#
6
# This program is free software: you can redistribute it and/or modify
7
# it under the terms of the GNU General Public License as published by
8
# the Free Software Foundation, either version 3 of the License, or
9
# (at your option) any later version.
10
#
11
# This program is distributed in the hope that it will be useful,
12
# but WITHOUT ANY WARRANTY; without even the implied warranty of
13
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
# GNU General Public License for more details.
15
#
16
# You should have received a copy of the GNU General Public License
17
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
18
"""
19
Module to store ospd configuration settings
20
"""
21
22
import configparser
23
import logging
24
25
logger = logging.getLogger(__name__)
26
27
class Config:
28
    def __init__(self, section='main'):
29
        self._config = configparser.ConfigParser(default_section=section)
30
        self._config = {}
31
        self._defaults = dict()
32
33
    def load(self, filepath, def_section='main'):
34
        path = filepath.expanduser()
35
36
        config = configparser.ConfigParser(default_section=def_section)
37
38
        with path.open() as f:
39
            config.read_file(f)
40
41
        self._defaults.update(config.defaults())
42
43
        for key, value in config.items(def_section):
44
                self._config.setdefault(def_section, dict())[key] = value
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable dict does not seem to be defined.
Loading history...
45
46
    def defaults(self):
47
        return self._defaults
48