--- - hosts: mpdb vars: share: - 'MUSIC' - 'MOVIES' localpath: '/mnt/' remotepath: '/pool/' hostname: "home.thrace-lan.info" username: "sshfs" sshfsport: 22000 tasks: - name: sshfs ansible.builtin.group: name: sshfs state: present - name: sshfs ansible.builtin.user: name: sshfs state: present group: sshfs - name: make ssh home directory file: path: "/home/sshfs/.ssh/" state: directory owner: sshfs group: sshfs mode: '0700' - name: copy private key copy: src: "./sshfs-key" dest: "/home/sshfs/.ssh/" owner: sshfs group: sshfs mode: '0700' notify: - SSHFS - name: copy ssh config copy: src: "./ssh-config" dest: "/home/sshfs/.ssh/config" owner: sshfs group: sshfs mode: '0700' notify: - SSHFS - name: "sshfs mount {{ item }}" file: path: "{{ localpath}}{{ item }}/" state: directory owner: root group: root mode: '0777' loop: "{{ share }}" notify: - SSHFS - name: Ensure fstab has sshfs ansible.builtin.lineinfile: path: /etc/fstab regexp: '^sshfs' line: "{{ [username,'@',hostname,':',remotepath,item,'/',' ',localpath,item,'/' ]|join() }} fuse.sshfs noauto,x-systemd.automount,_netdev,users,idmap=user,IdentityFile=/home/sshfs/.ssh/sshfs-key,allow_other,reconnect 0 0" handlers: - name: SSHFS ansible.builtin.command: "mount {{ [ localpath,item,'/' ]|join() }}"