1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- {% set tpl = ix_lib.base.render.Render(values) %}
- {% set c1 = tpl.add_container(values.consts.tailscale_container_name, "image") %}
- {% set perm_container = tpl.deps.perms(values.consts.perms_container_name) %}
- {% set perm_config = {"uid": 568, "gid": 568, "mode": "check"} %}
- {% do c1.add_caps(["NET_ADMIN", "NET_RAW", "SYS_MODULE", "CHOWN", "FOWNER", "DAC_OVERRIDE"]) %}
- {% do c1.healthcheck.set_custom_test("tailscale status") %}
- {% set args = namespace(x=[]) %}
- {% if values.tailscale.advertise_exit_node %}
- {% do args.x.append("--advertise-exit-node") %}
- {% endif %}
- {% if values.tailscale.reset %}
- {% do args.x.append("--reset") %}
- {% endif %}
- {% for arg in values.tailscale.extra_args %}
- {% for key in values.consts.reserved_keys %}
- {% if arg.startswith(key) %}
- {% do tpl.funcs.fail("Please use the dedicated field for [%s]"|format(key)) %}
- {% endif %}
- {% endfor %}
- {% do args.x.append(arg) %}
- {% endfor %}
- {% do c1.environment.add_env("TS_STATE_DIR", values.consts.state_path) %}
- {% do c1.environment.add_env("TS_ACCEPT_DNS", values.tailscale.accept_dns) %}
- {% do c1.environment.add_env("TS_HOSTNAME", values.tailscale.hostname) %}
- {% do c1.environment.add_env("TS_USERSPACE", values.tailscale.userspace) %}
- {% do c1.environment.add_env("TS_AUTH_ONCE", values.tailscale.auth_once) %}
- {% do c1.environment.add_env("TS_AUTHKEY", values.tailscale.auth_key) %}
- {% do c1.environment.add_env("TS_SOCKET", "/var/run/tailscale/tailscaled.sock") %}
- {% if values.tailscale.tailscaled_args %}
- {% do c1.environment.add_env("TS_TAILSCALED_EXTRA_ARGS", values.tailscale.tailscaled_args|unique|list|join(" ")) %}
- {% endif %}
- {% if values.tailscale.advertise_routes %}
- {% do c1.environment.add_env("TS_ROUTES", values.tailscale.advertise_routes|unique|list|join(",")) %}
- {% endif %}
- {% if args.x %}
- {% do c1.environment.add_env("TS_EXTRA_ARGS", args.x|join(" ")) %}
- {% endif %}
- {% do c1.environment.add_user_envs(values.tailscale.additional_envs) %}
- {% if not values.tailscale.userspace %}
- {% do c1.add_tun_device() %}
- {% endif %}
- {% do c1.add_storage("/var/run/tailscale", {"type":"tmpfs", "tmpfs_config": {"mode": "0755"}}) %}
- {% do c1.add_storage(values.consts.state_path, values.storage.state) %}
- {% if values.tailscale.userspace %}
- {% do perm_container.add_or_skip_action("state", values.storage.state, perm_config) %}
- {% endif %}
- {% for store in values.storage.additional_storage %}
- {% do c1.add_storage(store.mount_path, store) %}
- {% if values.tailscale.userspace %}
- {% do perm_container.add_or_skip_action(store.mount_path, store, perm_config) %}
- {% endif %}
- {% endfor %}
- {% if perm_container.has_actions() %}
- {% do perm_container.activate() %}
- {% do c1.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
- {% endif %}
- {{ tpl.render() | tojson }}
|