docker-compose.yaml 4.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. {% from "macros/setup.sh" import setup %}
  2. {% set tpl = ix_lib.base.render.Render(values) %}
  3. {% set c1 = tpl.add_container(values.consts.garage_container_name, "image") %}
  4. {% set web = namespace(x=None) %}
  5. {% set config = tpl.add_container(values.consts.config_container_name, "toml_image") %}
  6. {% set perm_container = tpl.deps.perms(values.consts.perms_container_name) %}
  7. {% set perms_config = {"uid": values.run_as.user, "gid": values.run_as.group, "mode": "check"} %}
  8. {# Config #}
  9. {% do config.set_user(values.run_as.user, values.run_as.group) %}
  10. {% do config.add_storage(values.consts.config_path, values.storage.config) %}
  11. {% do config.restart.set_policy("on-failure", 1) %}
  12. {% do config.healthcheck.disable() %}
  13. {% do config.deploy.resources.set_profile("low") %}
  14. {% do config.remove_devices() %}
  15. {% do config.configs.add("config", setup(values), "/config.sh", "0755") %}
  16. {% do config.set_entrypoint(["/config.sh"]) %}
  17. {# Web #}
  18. {% if values.network.web_port.bind_mode %}
  19. {% set web.x = tpl.add_container(values.consts.web_container_name, "web_image") %}
  20. {% do web.x.set_user(values.run_as.user, values.run_as.group) %}
  21. {% do web.x.healthcheck.set_test("curl", {"port": values.network.web_port.port_number}) %}
  22. {% do web.x.depends.add_dependency(values.consts.config_container_name, "service_completed_successfully") %}
  23. {% do web.x.depends.add_dependency(values.consts.garage_container_name, "service_healthy") %}
  24. {% do web.x.environment.add_env("PORT", values.network.web_port.port_number) %}
  25. {% do web.x.environment.add_env("CONFIG_PATH", "%s/garage.toml"|format(values.consts.config_path)) %}
  26. {% do web.x.environment.add_env("API_BASE_URL", "http://%s:%d"|format(values.consts.garage_container_name, values.network.admin_port.port_number)) %}
  27. {% do web.x.environment.add_env("API_ADMIN_KEY", values.garage.admin_token) %}
  28. {% do web.x.environment.add_env("S3_ENDPOINT_URL", "http://%s:%d"|format(values.consts.garage_container_name, values.network.s3_port.port_number)) %}
  29. {% if values.garage.enable_web_ui_auth %}
  30. {% do web.x.environment.add_env("AUTH_USER_PASS", tpl.funcs.htpasswd(values.garage.web_ui_username, values.garage.web_ui_password)) %}
  31. {% endif %}
  32. {% do web.x.add_port(values.network.web_port) %}
  33. {% do web.x.add_storage(values.consts.config_path, dict(values.storage.config, **{"read_only": true})) %}
  34. {% do tpl.portals.add(values.network.web_port) %}
  35. {% endif %}
  36. {# Main #}
  37. {% do c1.set_user(values.run_as.user, values.run_as.group) %}
  38. {% do c1.healthcheck.set_custom_test(["CMD", "/garage", "status"]) %}
  39. {% do c1.depends.add_dependency(values.consts.config_container_name, "service_completed_successfully") %}
  40. {% do c1.environment.add_env("GARAGE_CONFIG_FILE", "%s/garage.toml"|format(values.consts.config_path)) %}
  41. {% do c1.environment.add_env("GARAGE_ADMIN_TOKEN", values.garage.admin_token) %}
  42. {% do c1.environment.add_env("GARAGE_RPC_SECRET", values.garage.rpc_secret) %}
  43. {% do c1.environment.add_user_envs(values.garage.additional_envs) %}
  44. {% do c1.add_port(values.network.rpc_port) %}
  45. {% do c1.add_port(values.network.s3_port) %}
  46. {% do c1.add_port(values.network.s3_web_port) %}
  47. {% do c1.add_port(values.network.admin_port) %}
  48. {% do c1.add_storage(values.consts.config_path, values.storage.config) %}
  49. {% do perm_container.add_or_skip_action("config", values.storage.config, perms_config) %}
  50. {% do c1.add_storage(values.consts.metadata_path, values.storage.metadata) %}
  51. {% do perm_container.add_or_skip_action("metadata", values.storage.metadata, perms_config) %}
  52. {% do c1.add_storage(values.consts.data_path, values.storage.data) %}
  53. {% do perm_container.add_or_skip_action("data", values.storage.data, perms_config) %}
  54. {% do c1.add_storage(values.consts.metadata_snapshots_path, values.storage.metadata_snapshots) %}
  55. {% do perm_container.add_or_skip_action("metadata_snapshots", values.storage.metadata_snapshots, perms_config) %}
  56. {% for store in values.storage.additional_storage %}
  57. {% do c1.add_storage(store.mount_path, store) %}
  58. {% do perm_container.add_or_skip_action(store.mount_path, store, perms_config) %}
  59. {% endfor %}
  60. {% if perm_container.has_actions() %}
  61. {% do perm_container.activate() %}
  62. {% do c1.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  63. {% do config.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  64. {% if web.x %}
  65. {% do web.x.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  66. {% endif %}
  67. {% endif %}
  68. {{ tpl.render() | tojson }}