mirror of
https://git.ianrenton.com/ian/spothole.git
synced 2026-02-04 17:24:30 +00:00
31 lines
1.3 KiB
Python
31 lines
1.3 KiB
Python
import logging
|
|
import os
|
|
|
|
import yaml
|
|
|
|
# Check you have a config file
|
|
if not os.path.isfile("config.yml"):
|
|
logging.error(
|
|
"Your config file is missing. Ensure you have copied config-example.yml to config.yml and updated it according to your needs.")
|
|
exit()
|
|
|
|
# Load config
|
|
config = yaml.safe_load(open("config.yml"))
|
|
logging.info("Loaded config.")
|
|
|
|
MAX_SPOT_AGE = config["max-spot-age-sec"]
|
|
MAX_ALERT_AGE = config["max-alert-age-sec"]
|
|
SERVER_OWNER_CALLSIGN = config["server-owner-callsign"]
|
|
WEB_SERVER_PORT = config["web-server-port"]
|
|
ALLOW_SPOTTING = config["allow-spotting"]
|
|
WEB_UI_OPTIONS = config["web-ui-options"]
|
|
|
|
# For ease of config, each spot provider owns its own config about whether it should be enabled by default in the web UI
|
|
# but for consistency we provide this to the front-end in web-ui-options because it has no impact outside of the web UI.
|
|
WEB_UI_OPTIONS["spot-providers-enabled-by-default"] = [p["name"] for p in config["spot-providers"] if p["enabled"] and (
|
|
"enabled-by-default-in-web-ui" not in p or p["enabled-by-default-in-web-ui"] == True)]
|
|
# If spotting to this server is enabled, "API" is another valid spot source even though it does not come from
|
|
# one of our proviers. We set that to also be enabled by default.
|
|
if ALLOW_SPOTTING:
|
|
WEB_UI_OPTIONS["spot-providers-enabled-by-default"].append("API")
|