2022-10-08 15:55:40 +02:00
|
|
|
#!/usr/bin/env python3
|
2017-11-10 15:48:13 +02:00
|
|
|
|
|
|
|
import os
|
|
|
|
import glob
|
2019-01-07 23:49:10 +02:00
|
|
|
import logging as log
|
2022-10-27 10:51:45 +02:00
|
|
|
import requests
|
2019-01-07 23:49:10 +02:00
|
|
|
import sys
|
2022-10-27 10:51:45 +02:00
|
|
|
import time
|
2019-07-25 10:33:57 +02:00
|
|
|
from socrate import system, conf
|
2017-11-10 15:48:13 +02:00
|
|
|
|
2019-01-08 05:16:05 +02:00
|
|
|
log.basicConfig(stream=sys.stderr, level=os.environ.get("LOG_LEVEL", "WARNING"))
|
2019-01-07 23:49:10 +02:00
|
|
|
|
|
|
|
# Actual startup script
|
2019-05-07 11:42:08 +02:00
|
|
|
|
2019-08-23 08:43:59 +02:00
|
|
|
os.environ["REDIS_ADDRESS"] = system.get_host_address_from_environment("REDIS", "redis")
|
2021-10-14 19:07:11 +02:00
|
|
|
os.environ["ADMIN_ADDRESS"] = system.get_host_address_from_environment("ADMIN", "admin")
|
2018-10-22 16:02:43 +02:00
|
|
|
|
2019-08-22 12:08:43 +02:00
|
|
|
if os.environ.get("ANTIVIRUS") == 'clamav':
|
2019-08-23 08:43:59 +02:00
|
|
|
os.environ["ANTIVIRUS_ADDRESS"] = system.get_host_address_from_environment("ANTIVIRUS", "antivirus:3310")
|
2017-11-10 15:48:13 +02:00
|
|
|
|
|
|
|
for rspamd_file in glob.glob("/conf/*"):
|
2019-07-25 10:33:57 +02:00
|
|
|
conf.jinja(rspamd_file, os.environ, os.path.join("/etc/rspamd/local.d", os.path.basename(rspamd_file)))
|
2017-11-10 15:48:13 +02:00
|
|
|
|
2022-10-27 10:51:45 +02:00
|
|
|
# Admin may not be up just yet
|
|
|
|
healthcheck = f'http://{os.environ["ADMIN_ADDRESS"]}/internal/rspamd/local_domains'
|
|
|
|
while True:
|
|
|
|
time.sleep(1)
|
|
|
|
try:
|
|
|
|
if requests.get(healthcheck,timeout=2).ok:
|
|
|
|
break
|
|
|
|
except:
|
|
|
|
pass
|
2022-10-28 18:28:31 +02:00
|
|
|
log.warning("Admin is not up just yet, retrying in 1 second")
|
2022-10-27 10:51:45 +02:00
|
|
|
|
2017-11-10 15:48:13 +02:00
|
|
|
# Run rspamd
|
|
|
|
os.execv("/usr/sbin/rspamd", ["rspamd", "-i", "-f"])
|