testnet-ops/service-provider-setup/setup-user.yml

47 lines
1.2 KiB
YAML
Raw Normal View History

2024-09-18 10:08:38 +00:00
- name: Configure system
hosts: root_host
2024-09-18 10:08:38 +00:00
become: yes
vars_files:
- vars/user-vars.yml
2024-09-18 10:08:38 +00:00
tasks:
- name: Create a user
2024-09-18 10:08:38 +00:00
user:
name: "{{ username }}"
password: "{{ '{{ password }}' | password_hash('sha512') }}"
shell: /bin/bash
2024-09-18 10:08:38 +00:00
state: present
- name: Add user to sudoers group
2024-09-18 10:08:38 +00:00
user:
name: "{{ username }}"
2024-09-18 10:08:38 +00:00
groups: sudo
append: yes
- name: Ensure .ssh directory exists for user
2024-09-18 10:08:38 +00:00
file:
2024-09-27 07:33:36 +00:00
path: /home/{{ username }}/.ssh
2024-09-18 10:08:38 +00:00
state: directory
owner: "{{ username }}"
group: "{{ username }}"
2024-09-18 10:08:38 +00:00
mode: '0700'
2024-09-23 13:29:16 +00:00
2024-10-01 10:32:32 +00:00
- name: Append SSH public key to authorized_keys
lineinfile:
path: /home/{{ username }}/.ssh/authorized_keys
line: "{{ lookup('file', path_to_ssh_key) }}"
create: yes
owner: "{{ username }}"
group: "{{ username }}"
mode: '0600'
2024-10-01 10:32:32 +00:00
state: present
- name: Add user to sudoers for passwordless sudo
lineinfile:
path: /etc/sudoers
state: present
regexp: '^{{ username }} ALL=\(ALL\) NOPASSWD:ALL'
line: '{{ username }} ALL=(ALL) NOPASSWD:ALL'
validate: 'visudo -cf %s'