1
0
mirror of https://github.com/Mailu/Mailu.git synced 2024-12-14 10:53:30 +02:00
Mailu/core/dovecot/start.py

56 lines
1.9 KiB
Python
Raw Normal View History

2018-07-26 21:41:11 +02:00
#!/usr/bin/python3
import jinja2
import os
import socket
import glob
2018-07-26 21:41:11 +02:00
import multiprocessing
2018-10-07 00:39:02 +02:00
import tenacity
import logging as log
import sys
2018-07-26 21:41:11 +02:00
2018-10-06 23:32:05 +02:00
from tenacity import retry
2018-07-26 21:41:11 +02:00
from podop import run_server
2019-01-08 05:16:05 +02:00
log.basicConfig(stream=sys.stderr, level=os.environ.get("LOG_LEVEL", "WARNING"))
2018-07-26 21:41:11 +02:00
def start_podop():
os.setuid(8)
run_server(0, "dovecot", "/tmp/podop.socket", [
2018-09-27 07:55:54 +02:00
("quota", "url", "http://admin/internal/dovecot/§"),
("auth", "url", "http://admin/internal/dovecot/§"),
("sieve", "url", "http://admin/internal/dovecot/§"),
2018-07-26 21:41:11 +02:00
])
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
2018-10-22 16:02:43 +02:00
os.environ["FRONT_ADDRESS"] = resolve(os.environ.get("FRONT_ADDRESS", "front"))
os.environ["REDIS_ADDRESS"] = resolve(os.environ.get("REDIS_ADDRESS", "redis"))
if os.environ["WEBMAIL"] != "none":
os.environ["WEBMAIL_ADDRESS"] = resolve(os.environ.get("WEBMAIL_ADDRESS", "webmail"))
2018-09-27 16:13:02 +02:00
for dovecot_file in glob.glob("/conf/*.conf"):
2017-09-24 15:44:44 +02:00
convert(dovecot_file, os.path.join("/etc/dovecot", os.path.basename(dovecot_file)))
2018-07-26 21:41:11 +02:00
# Run Podop, then postfix
multiprocessing.Process(target=start_podop).start()
os.system("chown mail:mail /mail")
os.system("chown -R mail:mail /var/lib/dovecot /conf")
2017-09-24 15:44:44 +02:00
os.execv("/usr/sbin/dovecot", ["dovecot", "-c", "/etc/dovecot/dovecot.conf", "-F"])