improve tailscale add

This commit is contained in:
counterweight 2025-12-13 18:54:46 +01:00
parent 0b578ee738
commit 2893bb77cd
Signed by: counterweight
GPG key ID: 883EDBAA726BD96C

View file

@ -77,7 +77,7 @@
- name: Add Tailscale repository
apt_repository:
repo: "deb [signed-by=/etc/apt/keyrings/tailscale.gpg] https://pkgs.tailscale.com/stable/debian {{ ansible_lsb.codename }} main"
repo: "deb [signed-by=/etc/apt/keyrings/tailscale.gpg] https://pkgs.tailscale.com/stable/debian {{ ansible_distribution_release }} main"
state: present
update_cache: yes
@ -99,6 +99,8 @@
--login-server {{ headscale_domain }}
--authkey {{ auth_key }}
--accept-dns=true
--hostname={{ ansible_hostname }}
--reset
register: tailscale_up_result
changed_when: "'already authenticated' not in tailscale_up_result.stdout"
failed_when: tailscale_up_result.rc != 0 and 'already authenticated' not in tailscale_up_result.stdout
@ -107,6 +109,37 @@
pause:
seconds: 2
- name: Get node ID from headscale server
delegate_to: "{{ groups['lapy'][0] }}"
become: no
vars:
ssh_args: "{{ ('-i ' + headscale_key + ' ' if headscale_key else '') + '-p ' + headscale_port|string }}"
shell: >
ssh {{ ssh_args }}
{{ headscale_user }}@{{ headscale_host }}
"sudo headscale nodes list -o json"
register: nodes_list_result
changed_when: false
failed_when: nodes_list_result.rc != 0
- name: Extract node ID for this host
set_fact:
headscale_node_id: "{{ (nodes_list_result.stdout | from_json) | selectattr('given_name', 'equalto', ansible_hostname) | map(attribute='id') | first }}"
failed_when: headscale_node_id is not defined or headscale_node_id == ''
- name: Tag node with its hostname
delegate_to: "{{ groups['lapy'][0] }}"
become: no
vars:
ssh_args: "{{ ('-i ' + headscale_key + ' ' if headscale_key else '') + '-p ' + headscale_port|string }}"
shell: >
ssh {{ ssh_args }}
{{ headscale_user }}@{{ headscale_host }}
"sudo headscale nodes tag --tags tag:{{ ansible_hostname }} -i {{ headscale_node_id }}"
register: tag_result
changed_when: true
failed_when: tag_result.rc != 0
- name: Display Tailscale status
command: tailscale status
register: tailscale_status
@ -115,10 +148,3 @@
- name: Show Tailscale connection status
debug:
msg: "{{ tailscale_status.stdout_lines }}"
- name: Deny all inbound traffic from Tailscale network interface
ufw:
rule: deny
direction: in
interface: tailscale0