docker-compose.yaml 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. {% set tpl = ix_lib.base.render.Render(values) %}
  2. {% set frontend = tpl.add_container(values.consts.penpot_frontend_container_name, "image") %}
  3. {% set backend = tpl.add_container(values.consts.penpot_backend_container_name, "backend_image") %}
  4. {% set exporter = tpl.add_container(values.consts.penpot_exporter_container_name, "exporter_image") %}
  5. {% set perm_container = tpl.deps.perms(values.consts.perms_container_name) %}
  6. {% set pg_config = {
  7. "user": values.consts.db_user,
  8. "password": values.penpot.db_password,
  9. "database": values.consts.db_name,
  10. "volume": values.storage.postgres_data,
  11. } %}
  12. {% set postgres = tpl.deps.postgres(
  13. values.consts.postgres_container_name,
  14. values.penpot.postgres_image_selector,
  15. pg_config, perm_container
  16. ) %}
  17. {% set redis_config = {
  18. "password": values.penpot.redis_password,
  19. "volume": {"type": "temporary", "volume_config": {"volume_name": "redis-data"}},
  20. } %}
  21. {% set redis = tpl.deps.redis(values.consts.redis_container_name, "redis_image", redis_config, perm_container) %}
  22. {% do backend.depends.add_dependency(values.consts.postgres_container_name, "service_healthy") %}
  23. {% do backend.depends.add_dependency(values.consts.redis_container_name, "service_healthy") %}
  24. {% do exporter.depends.add_dependency(values.consts.penpot_backend_container_name, "service_healthy") %}
  25. {% do frontend.depends.add_dependency(values.consts.penpot_backend_container_name, "service_healthy") %}
  26. {% do backend.set_user(values.consts.run_as_user, values.consts.run_as_group) %}
  27. {% do exporter.set_user(values.consts.run_as_user, values.consts.run_as_group) %}
  28. {% do frontend.set_user(values.consts.run_as_user, values.consts.run_as_group) %}
  29. {% do backend.healthcheck.set_test("http", {"port": values.consts.backend_port, "path": "/readyz"}) %}
  30. {% do exporter.healthcheck.set_test("curl", {"port": values.consts.exporter_port, "path": "/readyz"}) %}
  31. {% do frontend.healthcheck.set_test("curl", {"port": values.consts.frontend_port, "path": "/readyz"}) %}
  32. {% set perms_config = {"uid": values.consts.run_as_user, "gid": values.consts.run_as_group, "mode": "check", "chmod": "0777"} %}
  33. {% do backend.add_storage(values.consts.assets_path, values.storage.assets) %}
  34. {% do frontend.add_storage(values.consts.assets_path, values.storage.assets) %}
  35. {% do perm_container.add_or_skip_action("assets", values.storage.assets, perms_config) %}
  36. {% for store in values.storage.additional_storage %}
  37. {% do backend.add_storage(store.mount_path, store) %}
  38. {% do perm_container.add_or_skip_action(store.mount_path, store, perms_config) %}
  39. {% endfor %}
  40. {% set redis_uri = "redis://default:%s@%s:6379/0"|format(values.penpot.redis_password, values.consts.redis_container_name) %}
  41. {% do backend.environment.add_env("PENPOT_HTTP_SERVER_PORT", values.consts.backend_port) %}
  42. {% do backend.environment.add_env("PENPOT_HTTP_SERVER_HOST", "0.0.0.0") %}
  43. {% do backend.environment.add_env("PENPOT_REDIS_URI", redis_uri) %}
  44. {% do backend.environment.add_env("PENPOT_DATABASE_USERNAME", values.consts.db_user) %}
  45. {% do backend.environment.add_env("PENPOT_DATABASE_PASSWORD", values.penpot.db_password) %}
  46. {% do backend.environment.add_env("PENPOT_DATABASE_URI", postgres.get_url("postgresql_no_creds")) %}
  47. {% do backend.environment.add_env("PENPOT_OBJECTS_STORAGE_BACKEND", "fs") %}
  48. {% do backend.environment.add_env("PENPOT_SECRET_KEY", values.penpot.secret_key) %}
  49. {% do backend.environment.add_env("PENPOT_OBJECTS_STORAGE_FS_DIRECTORY", values.consts.assets_path) %}
  50. {% do backend.environment.add_env("PENPOT_PUBLIC_URI", values.penpot.public_uri) %}
  51. {% do backend.environment.add_user_envs(values.penpot.additional_envs) %}
  52. {% do backend.environment.add_env("PENPOT_TELEMETRY_ENABLED", "true") %}
  53. {% do backend.environment.add_env("PENPOT_TELEMETRY_REFERER", "truenas") %}
  54. {% do exporter.environment.add_env("PENPOT_PUBLIC_URI", values.penpot.public_uri) %}
  55. {% do exporter.environment.add_env("PENPOT_REDIS_URI", redis_uri) %}
  56. {% do exporter.environment.add_env("PENPOT_HTTP_SERVER_PORT", values.consts.exporter_port) %}
  57. {% do exporter.environment.add_env("PENPOT_HTTP_SERVER_HOST", "0.0.0.0") %}
  58. {% do frontend.environment.add_env("PENPOT_PUBLIC_URI", values.penpot.public_uri) %}
  59. {% do frontend.environment.add_env("PENPOT_BACKEND_URI", "http://%s:%d"|format(values.consts.penpot_backend_container_name, values.consts.backend_port)) %}
  60. {% do frontend.environment.add_env("PENPOT_EXPORTER_URI", "http://%s:%d"|format(values.consts.penpot_exporter_container_name, values.consts.exporter_port)) %}
  61. {% set flags = namespace(x=[]) %}
  62. {% set flag_names = values.penpot.flags | map(attribute="name") | list %}
  63. {% if flag_names | unique | list | length != flag_names | length %}
  64. {% do tpl.funcs.fail("Flag names must be unique, got [%s]"|format(flag_names | join(", "))) %}
  65. {% endif %}
  66. {% for flag in values.penpot.flags %}
  67. {% if flag.name.startswith("enable-") or flag.name.startswith("disable-") %}
  68. {% do tpl.funcs.fail("Flag name [%s] cannot start with [enable-] or [disable-], use the checkbox instead."|format(flag.name)) %}
  69. {% endif %}
  70. {% do flags.x.append("%s-%s"|format("enable" if flag.enable else "disable", flag.name)) %}
  71. {% endfor %}
  72. {% if flags.x %}
  73. {% do backend.environment.add_env("PENPOT_FLAGS", " ".join(flags.x)) %}
  74. {% do frontend.environment.add_env("PENPOT_FLAGS", " ".join(flags.x)) %}
  75. {% do exporter.environment.add_env("PENPOT_FLAGS", " ".join(flags.x)) %}
  76. {% endif %}
  77. {% do frontend.add_port(values.network.web_port, {"container_port": values.consts.frontend_port}) %}
  78. {% if perm_container.has_actions() %}
  79. {% do perm_container.activate() %}
  80. {% do postgres.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  81. {% do redis.container.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  82. {% do backend.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  83. {% do exporter.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  84. {% do frontend.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  85. {% endif %}
  86. {% do tpl.portals.add(values.network.web_port) %}
  87. {{ tpl.render() | tojson }}