diff options
author | kaiyou <pierre@jaury.eu> | 2018-02-03 20:18:36 +0100 |
---|---|---|
committer | kaiyou <pierre@jaury.eu> | 2018-02-03 20:18:36 +0100 |
commit | 431476fbc4ef0c740e33e19ccc73996c2412e4f9 (patch) | |
tree | 1b7cc0265039cbdf4128c000b252908aebcf22ac /contrib/docker/start.py | |
parent | Merge pull request #2798 from jeremycline/fedora-repo (diff) | |
download | synapse-431476fbc4ef0c740e33e19ccc73996c2412e4f9.tar.xz |
Initial commit including a Dockerfile for synapse
Diffstat (limited to 'contrib/docker/start.py')
-rwxr-xr-x | contrib/docker/start.py | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/contrib/docker/start.py b/contrib/docker/start.py new file mode 100755 index 0000000000..4f63ea1ad5 --- /dev/null +++ b/contrib/docker/start.py @@ -0,0 +1,29 @@ +#!/usr/local/bin/python + +import jinja2 +import os +import sys +import socket + +convert = lambda src, dst: open(dst, "w").write(jinja2.Template(open(src).read()).render(**os.environ)) +mode = sys.argv[1] if len(sys.argv) > 1 else None + +if "SYNAPSE_SERVER_NAME" not in os.environ: + print("Environment variable SYNAPSE_SERVER_NAME is mandatory, exiting.") + sys.exit(2) + +params = ["--server-name", os.environ.get("SYNAPSE_SERVER_NAME"), + "--report-stats", os.environ.get("SYNAPSE_REPORT_STATS", "no"), + "--config-path", os.environ.get("SYNAPSE_CONFIG_PATH", "/compiled/homeserver.yaml")] + +if mode == "generate": + params.append("--generate-config") + +# Parse the configuration file +if not os.path.exists("/compiled"): + os.mkdir("/compiled") +convert("/conf/homeserver.yaml", "/compiled/homeserver.yaml") +convert("/conf/log.config", "/compiled/%s.log.config" % os.environ.get("SYNAPSE_SERVER_NAME")) + +# TODO, replace with a call to synapse.app.homeserver.run() +os.execv("/usr/local/bin/python", ["python", "-m", "synapse.app.homeserver"] + params) |