Split the main run function to allow the use of radicale serving programatically. Add an extra_config parameter to the config load to override config.

This commit is contained in:
Florian Mounier 2016-07-05 17:50:40 +02:00
parent 383409213e
commit a7549bc652
2 changed files with 10 additions and 1 deletions

View File

@ -107,6 +107,11 @@ def run():
if not configuration_found: if not configuration_found:
logger.warning("Configuration file '%s' not found" % options.config) logger.warning("Configuration file '%s' not found" % options.config)
serve(configuration, logger)
def serve(configuration, logger):
"""Serve radicale from configuration"""
# Fork if Radicale is launched as daemon # Fork if Radicale is launched as daemon
if configuration.getboolean("server", "daemon"): if configuration.getboolean("server", "daemon"):
# Check and create PID file in a race-free manner # Check and create PID file in a race-free manner

View File

@ -65,12 +65,16 @@ INITIAL_CONFIG = {
"mask_passwords": "True"}} "mask_passwords": "True"}}
def load(paths=()): def load(paths=(), extra_config=None):
config = ConfigParser() config = ConfigParser()
for section, values in INITIAL_CONFIG.items(): for section, values in INITIAL_CONFIG.items():
config.add_section(section) config.add_section(section)
for key, value in values.items(): for key, value in values.items():
config.set(section, key, value) config.set(section, key, value)
if extra_config:
for section, values in extra_config.items():
for key, value in values.items():
config.set(section, key, value)
for path in paths: for path in paths:
if path: if path:
config.read(path) config.read(path)