2016-11-07 14:00:57 +01:00
|
|
|
---
|
|
|
|
|
|
|
|
|
2017-06-12 14:28:48 +02:00
|
|
|
- name: "Create .ssh directory for '{{ user.name }}'"
|
2016-11-07 14:00:57 +01:00
|
|
|
file:
|
|
|
|
dest: '/home/{{ user.name }}/.ssh/'
|
|
|
|
state: directory
|
2017-03-23 16:59:43 +01:00
|
|
|
mode: "0700"
|
2016-11-07 14:00:57 +01:00
|
|
|
owner: '{{ user.name }}'
|
|
|
|
group: '{{ user.name }}'
|
|
|
|
|
2017-06-12 14:28:48 +02:00
|
|
|
- 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
|
2017-10-06 00:51:20 +02:00
|
|
|
when: user.ssh_key is defined
|
|
|
|
|
|
|
|
- name: "Add user's SSH public keys for '{{ user.name }}'"
|
|
|
|
authorized_key:
|
|
|
|
user: "{{ user.name }}"
|
|
|
|
key: "{{ ssk_key }}"
|
|
|
|
state: present
|
|
|
|
with_items: "{{ user.ssh_keys }}"
|
|
|
|
loop_control:
|
|
|
|
loop_var: ssk_key
|
|
|
|
when: user.ssh_keys is defined
|
2016-12-27 14:04:02 +01:00
|
|
|
|
2017-07-19 12:33:35 +02:00
|
|
|
# we must double-escape caracters, because python
|
2016-12-27 14:04:02 +01:00
|
|
|
- name: verify AllowUsers directive
|
2017-07-19 13:54:18 +02:00
|
|
|
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
|
|
|
|
|
2017-06-12 14:28:48 +02:00
|
|
|
- name: "Add AllowUsers sshd directive for '{{ user.name }}'"
|
2016-11-07 14:00:57 +01:00
|
|
|
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
|
2016-11-07 14:00:57 +01:00
|
|
|
|
2017-06-12 14:28:48 +02:00
|
|
|
- name: "Modify AllowUsers sshd directive for '{{ user.name }}'"
|
2016-11-07 14:00:57 +01:00
|
|
|
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
|
|
|
|
|
2017-06-12 14:28:48 +02:00
|
|
|
- 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
|
2016-11-07 14:00:57 +01:00
|
|
|
|
2017-06-12 14:28:48 +02:00
|
|
|
- name: "Modify Match User's sshd directive for '{{ user.name }}'"
|
2016-11-07 14:00:57 +01:00
|
|
|
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
|