···
logger.info("Loaded configuration from .env file")
-
# Load Zulip configuration
zulip_config = ZulipConfig(
-
site=os.getenv("ZULIP_SITE", ""),
-
email=os.getenv("ZULIP_EMAIL", ""),
-
api_key=os.getenv("ZULIP_API_KEY", ""),
stream=os.getenv("ZULIP_STREAM", "netdata-alerts"),
-
# Validate required Zulip settings
-
if not all([zulip_config.site, zulip_config.email, zulip_config.api_key]):
-
"Missing required Zulip configuration. Please set ZULIP_SITE, "
-
"ZULIP_EMAIL, and ZULIP_API_KEY environment variables."
# Load server configuration
server_config = ServerConfig(
host=os.getenv("SERVER_HOST", "0.0.0.0"),
-
port=int(os.getenv("SERVER_PORT", "8443")),
-
domain=os.getenv("SERVER_DOMAIN", ""),
-
cert_path=os.getenv("SERVER_CERT_PATH", "./certs"),
-
enable_mtls=os.getenv("SERVER_ENABLE_MTLS", "true").lower() == "true",
-
auto_cert=os.getenv("SERVER_AUTO_CERT", "false").lower() == "true",
-
cert_email=os.getenv("SERVER_CERT_EMAIL", ""),
-
cert_staging=os.getenv("SERVER_CERT_STAGING", "false").lower() == "true",
-
acme_port=int(os.getenv("SERVER_ACME_PORT", "80")),
-
# Validate required server settings
-
if not server_config.domain:
-
"Missing required server configuration. Please set SERVER_DOMAIN "
-
"environment variable."
-
# Validate auto-cert specific settings
-
if server_config.auto_cert and not server_config.cert_email:
-
"When SERVER_AUTO_CERT is enabled, SERVER_CERT_EMAIL must be set "
-
"for Let's Encrypt account registration."
-
zulip_site=zulip_config.site,
-
zulip_email=zulip_config.email,
zulip_stream=zulip_config.stream,
server_host=server_config.host,
server_port=server_config.port,
-
server_domain=server_config.domain,
-
mtls_enabled=server_config.enable_mtls,
-
auto_cert=server_config.auto_cert,
-
cert_staging=server_config.cert_staging,
return zulip_config, server_config
···
api_key=config.get('key', ''),
stream=config.get('stream', 'netdata-alerts'),
"Loaded Zulip configuration from zuliprc",
···
logger.info("Loaded configuration from .env file")
+
# Load Zulip configuration (optional from env, main source should be zuliprc)
zulip_config = ZulipConfig(
+
site=os.getenv("ZULIP_SITE"),
+
email=os.getenv("ZULIP_EMAIL"),
+
api_key=os.getenv("ZULIP_API_KEY"),
stream=os.getenv("ZULIP_STREAM", "netdata-alerts"),
# Load server configuration
server_config = ServerConfig(
host=os.getenv("SERVER_HOST", "0.0.0.0"),
+
port=int(os.getenv("SERVER_PORT", "8080")),
+
zulip_site=zulip_config.site or "(from zuliprc)",
+
zulip_email=zulip_config.email or "(from zuliprc)",
zulip_stream=zulip_config.stream,
server_host=server_config.host,
server_port=server_config.port,
return zulip_config, server_config
···
api_key=config.get('key', ''),
stream=config.get('stream', 'netdata-alerts'),
+
# Validate required fields from zuliprc
+
if not all([zulip_config.site, zulip_config.email, zulip_config.api_key]):
+
if not zulip_config.site: missing.append('site')
+
if not zulip_config.email: missing.append('email')
+
if not zulip_config.api_key: missing.append('key')
+
f"Missing required Zulip configuration in {zuliprc_path}: {', '.join(missing)}"
"Loaded Zulip configuration from zuliprc",