summary refs log tree commit diff
path: root/contrib/docker/start.py
diff options
context:
space:
mode:
authorkaiyou <pierre@jaury.eu>2018-02-03 20:18:36 +0100
committerkaiyou <pierre@jaury.eu>2018-02-03 20:18:36 +0100
commit431476fbc4ef0c740e33e19ccc73996c2412e4f9 (patch)
tree1b7cc0265039cbdf4128c000b252908aebcf22ac /contrib/docker/start.py
parentMerge pull request #2798 from jeremycline/fedora-repo (diff)
downloadsynapse-431476fbc4ef0c740e33e19ccc73996c2412e4f9.tar.xz
Initial commit including a Dockerfile for synapse
Diffstat (limited to 'contrib/docker/start.py')
-rwxr-xr-xcontrib/docker/start.py29
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)