ansible-roles/evolinux-users/tasks/ssh.yml

67 lines
1.9 KiB
YAML
Raw Normal View History

---
- name: "Create .ssh directory for '{{ user.name }}'"
file:
dest: '/home/{{ user.name }}/.ssh/'
state: directory
mode: "0700"
owner: '{{ user.name }}'
group: '{{ user.name }}'
- name: "Add user's SSH public key for '{{ user.name }}'"
2016-12-27 14:04:02 +01:00
authorized_key:
user: "{{ user.name }}"
key: "{{ user.ssh_key }}"
state: present
# we must double-escape caracters, because python
2016-12-27 14:04:02 +01:00
- name: verify AllowUsers directive
shell: "egrep '^AllowUsers' /etc/ssh/sshd_config"
2016-12-27 14:04:02 +01:00
changed_when: False
failed_when: False
register: grep_allowusers_ssh
2017-03-24 14:15:09 +01:00
check_mode: no
- name: "Add AllowUsers sshd directive for '{{ user.name }}'"
lineinfile:
2016-12-27 14:04:02 +01:00
dest: /etc/ssh/sshd_config
line: "\nAllowUsers {{ user.name }}"
2017-08-05 18:13:24 +02:00
insertafter: 'Subsystem'
2016-12-27 14:04:02 +01:00
validate: '/usr/sbin/sshd -T -f %s'
2017-01-04 10:21:27 +01:00
notify: reload sshd
2016-12-27 14:04:02 +01:00
when: grep_allowusers_ssh.rc != 0
- name: "Modify AllowUsers sshd directive for '{{ user.name }}'"
replace:
dest: /etc/ssh/sshd_config
regexp: '^(AllowUsers ((?!{{ user.name }}).)*)$'
replace: '\1 {{ user.name }}'
2016-12-27 14:04:02 +01:00
validate: '/usr/sbin/sshd -T -f %s'
2017-01-04 10:21:27 +01:00
notify: reload sshd
2016-12-27 14:04:02 +01:00
when: grep_allowusers_ssh.rc == 0
- name: verify Match User directive
command: "grep 'Match User' /etc/ssh/sshd_config"
changed_when: False
failed_when: False
register: grep_matchuser_ssh
2017-03-24 14:15:09 +01:00
check_mode: no
- name: "Add Match User sshd directive for '{{ user.name }}'"
2016-12-27 14:04:02 +01:00
lineinfile:
dest: /etc/ssh/sshd_config
line: "\nMatch User {{ user.name }}\n PasswordAuthentication no"
validate: '/usr/sbin/sshd -T -f %s'
2017-01-04 10:21:27 +01:00
notify: reload sshd
2016-12-27 14:04:02 +01:00
when: grep_matchuser_ssh.rc != 0
- name: "Modify Match User's sshd directive for '{{ user.name }}'"
replace:
dest: /etc/ssh/sshd_config
regexp: '^(Match User ((?!{{ user.name }}).)*)$'
replace: '\1,{{ user.name }}'
2016-12-27 14:04:02 +01:00
validate: '/usr/sbin/sshd -T -f %s'
2017-01-04 10:21:27 +01:00
notify: reload sshd
2016-12-27 14:04:02 +01:00
when: grep_matchuser_ssh.rc == 0