ansible-roles/evolinux-admin-users/tasks/adduser_debian.yml

96 lines
2.6 KiB
YAML

---
- name: Test if uid exists for '{{ user.name }}'
command: 'getent passwd {{ user.uid }}'
register: uidisbusy
failed_when: False
changed_when: False
- name: Add Unix account with classical uid for '{{ user.name }}'
user:
state: present
uid: '{{ user.uid }}'
name: '{{ user.name }}'
comment: '{{ user.fullname }}'
shell: /bin/bash
password: '{{ user.password_hash }}'
update_password: on_create
when: uidisbusy|failed
- name: Add Unix account with random uid for '{{ user.name }}'
user:
state: present
name: '{{ user.name }}'
comment: '{{ user.fullname }}'
shell: /bin/bash
password: '{{ user.password_hash }}'
update_password: on_create
when: uidisbusy|success
- name: Fix perms on homedirectory for '{{ user.name }}'
file:
name: '/home/{{ user.name }}'
mode: 0700
state: directory
- name: is evomaintenance installed?
stat:
path: "{{ evomaintenance_scripts_dir or general_scripts_dir | mandatory }}/evomaintenance.sh"
register: evomaintenance_script
- name: Add evomaintenance trap for '{{ user.name }}'
lineinfile:
state: present
dest: '/home/{{ user.name }}/.profile'
insertafter: EOF
line: 'trap "sudo {{ evomaintenance_scripts_dir or general_scripts_dir | mandatory }}/evomaintenance.sh" 0'
when: evomaintenance_script.stat.exists
- 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 }}'
lineinfile:
dest: '/home/{{ user.name }}/.ssh/authorized_keys'
create: yes
line: '{{ user.ssh_key }}'
owner: '{{ user.name }}'
group: '{{ user.name }}'
- name: Modify AllowUsers' sshd directive for '{{ user.name }}'
replace:
dest: /etc/ssh/sshd_config
regexp: '^(AllowUsers ((?!{{ user.name }}).)*)$'
replace: '\1 {{ user.name }}'
notify:
- reload sshd
- 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 }}'
notify:
- reload sshd
- name: Evolinux sudoers file is present
template:
src: sudoers_debian.j2
dest: /etc/sudoers.d/evolinux
force: false
validate: '/usr/sbin/visudo -cf %s'
register: copy_sudoers_evolinux
- name: Add user in sudoers file for '{{ user.name }}'
replace:
dest: /etc/sudoers.d/evolinux
regexp: '^(User_Alias\s+ADMINS\s+=((?!{{ user.name }}).)*)$'
replace: '\1,{{ user.name }}'
validate: '/usr/sbin/visudo -cf %s'
when: not copy_sudoers_evolinux.changed