docker-compose.yaml 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. {% set tpl = ix_lib.base.render.Render(values) %}
  2. {% set proto = "https" if values.network.use_https else "http" %}
  3. {% set c1 = tpl.add_container(values.consts.mineos_container_name, "image") %}
  4. {% do c1.add_caps(["CHOWN", "DAC_OVERRIDE", "FOWNER", "SETGID", "SETUID"]) %}
  5. {% do c1.set_grace_period(values.mineos.stop_grace_period) %}
  6. {% do c1.healthcheck.set_test("curl", {"port": values.network.web_port.port_number, "path": "/admin/login.html", "scheme": proto}) %}
  7. {% do c1.environment.add_env("USER_UID", values.run_as.user) %}
  8. {% do c1.environment.add_env("GROUP_GID", values.run_as.group) %}
  9. {% do c1.environment.add_env("GROUP_NAME", values.mineos.username) %}
  10. {% do c1.environment.add_env("USER_NAME", values.mineos.username) %}
  11. {% do c1.environment.add_env("USER_PASSWORD", values.mineos.password) %}
  12. {% do c1.environment.add_env("SERVER_PORT", values.network.web_port.port_number) %}
  13. {% do c1.environment.add_env("USE_HTTPS", values.network.use_https|string|lower) %}
  14. {% do c1.environment.add_user_envs(values.mineos.additional_envs) %}
  15. {% if values.network.certificate_id %}
  16. {% set cert = values.ix_certificates[values.network.certificate_id] %}
  17. {% do c1.configs.add("private", cert.privatekey, "/etc/ssl/certs/mineos.key") %}
  18. {% do c1.configs.add("public", cert.certificate, "/etc/ssl/certs/mineos.crt") %}
  19. {% endif %}
  20. {% do c1.add_port(values.network.web_port) %}
  21. {% for port in values.network.additional_ports %}
  22. {% do c1.add_port(port) %}
  23. {% endfor %}
  24. {% do c1.add_storage("/var/games/minecraft", values.storage.data) %}
  25. {% for store in values.storage.additional_storage %}
  26. {% do c1.add_storage(store.mount_path, store) %}
  27. {% endfor %}
  28. {% do tpl.portals.add(values.network.web_port, {"scheme": proto}) %}
  29. {{ tpl.render() | tojson }}