|
|
|
#!/usr/bin/python3
|
|
|
|
|
|
|
|
import jinja2
|
|
|
|
import os
|
|
|
|
import socket
|
|
|
|
import glob
|
|
|
|
import tenacity
|
|
|
|
import logging as log
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from tenacity import retry
|
|
|
|
|
|
|
|
log.basicConfig(stream=sys.stderr, level=os.environ.get("LOG_LEVEL", "WARNING"))
|
|
|
|
|
|
|
|
def convert(src, dst):
|
|
|
|
logger = log.getLogger("convert()")
|
|
|
|
logger.debug("Source: %s, Destination: %s", src, dst)
|
|
|
|
open(dst, "w").write(jinja2.Template(open(src).read()).render(**os.environ))
|
|
|
|
|
|
|
|
@retry(
|
|
|
|
stop=tenacity.stop_after_attempt(100),
|
|
|
|
wait=tenacity.wait_random(min=2, max=5),
|
|
|
|
before=tenacity.before_log(log.getLogger("tenacity.retry"), log.DEBUG),
|
|
|
|
before_sleep=tenacity.before_sleep_log(log.getLogger("tenacity.retry"), log.INFO),
|
|
|
|
after=tenacity.after_log(log.getLogger("tenacity.retry"), log.DEBUG)
|
|
|
|
)
|
|
|
|
def resolve(hostname):
|
|
|
|
logger = log.getLogger("resolve()")
|
|
|
|
logger.info(hostname)
|
|
|
|
return socket.gethostbyname(hostname)
|
|
|
|
|
|
|
|
# Actual startup script
|
|
|
|
os.environ["FRONT_ADDRESS"] = resolve(os.environ.get("FRONT_ADDRESS", "front"))
|
|
|
|
|
|
|
|
if "HOST_REDIS" not in os.environ: os.environ["HOST_REDIS"] = "redis"
|
|
|
|
|
|
|
|
for rspamd_file in glob.glob("/conf/*"):
|
|
|
|
convert(rspamd_file, os.path.join("/etc/rspamd/local.d", os.path.basename(rspamd_file)))
|
|
|
|
|
|
|
|
# Run rspamd
|
|
|
|
os.execv("/usr/sbin/rspamd", ["rspamd", "-i", "-f"])
|