docker-compose.yaml 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. {% set tpl = ix_lib.base.render.Render(values) %}
  2. {% set c1 = tpl.add_container(values.consts.tailscale_container_name, "image") %}
  3. {% set perm_container = tpl.deps.perms(values.consts.perms_container_name) %}
  4. {% set perm_config = {"uid": 568, "gid": 568, "mode": "check"} %}
  5. {% do c1.add_caps(["NET_ADMIN", "NET_RAW", "SYS_MODULE", "CHOWN", "FOWNER", "DAC_OVERRIDE"]) %}
  6. {% do c1.healthcheck.set_custom_test("tailscale status") %}
  7. {% set args = namespace(x=[]) %}
  8. {% if values.tailscale.advertise_exit_node %}
  9. {% do args.x.append("--advertise-exit-node") %}
  10. {% endif %}
  11. {% if values.tailscale.reset %}
  12. {% do args.x.append("--reset") %}
  13. {% endif %}
  14. {% for arg in values.tailscale.extra_args %}
  15. {% for key in values.consts.reserved_keys %}
  16. {% if arg.startswith(key) %}
  17. {% do tpl.funcs.fail("Please use the dedicated field for [%s]"|format(key)) %}
  18. {% endif %}
  19. {% endfor %}
  20. {% do args.x.append(arg) %}
  21. {% endfor %}
  22. {% do c1.environment.add_env("TS_STATE_DIR", values.consts.state_path) %}
  23. {% do c1.environment.add_env("TS_ACCEPT_DNS", values.tailscale.accept_dns) %}
  24. {% do c1.environment.add_env("TS_HOSTNAME", values.tailscale.hostname) %}
  25. {% do c1.environment.add_env("TS_USERSPACE", values.tailscale.userspace) %}
  26. {% do c1.environment.add_env("TS_AUTH_ONCE", values.tailscale.auth_once) %}
  27. {% do c1.environment.add_env("TS_AUTHKEY", values.tailscale.auth_key) %}
  28. {% do c1.environment.add_env("TS_SOCKET", "/var/run/tailscale/tailscaled.sock") %}
  29. {% if values.tailscale.tailscaled_args %}
  30. {% do c1.environment.add_env("TS_TAILSCALED_EXTRA_ARGS", values.tailscale.tailscaled_args|unique|list|join(" ")) %}
  31. {% endif %}
  32. {% if values.tailscale.advertise_routes %}
  33. {% do c1.environment.add_env("TS_ROUTES", values.tailscale.advertise_routes|unique|list|join(",")) %}
  34. {% endif %}
  35. {% if args.x %}
  36. {% do c1.environment.add_env("TS_EXTRA_ARGS", args.x|join(" ")) %}
  37. {% endif %}
  38. {% do c1.environment.add_user_envs(values.tailscale.additional_envs) %}
  39. {% if not values.tailscale.userspace %}
  40. {% do c1.add_tun_device() %}
  41. {% endif %}
  42. {% do c1.add_storage("/var/run/tailscale", {"type":"tmpfs", "tmpfs_config": {"mode": "0755"}}) %}
  43. {% do c1.add_storage(values.consts.state_path, values.storage.state) %}
  44. {% if values.tailscale.userspace %}
  45. {% do perm_container.add_or_skip_action("state", values.storage.state, perm_config) %}
  46. {% endif %}
  47. {% for store in values.storage.additional_storage %}
  48. {% do c1.add_storage(store.mount_path, store) %}
  49. {% if values.tailscale.userspace %}
  50. {% do perm_container.add_or_skip_action(store.mount_path, store, perm_config) %}
  51. {% endif %}
  52. {% endfor %}
  53. {% if perm_container.has_actions() %}
  54. {% do perm_container.activate() %}
  55. {% do c1.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  56. {% endif %}
  57. {{ tpl.render() | tojson }}