53 lines
1.6 KiB
YAML
53 lines
1.6 KiB
YAML
---
|
|
- name: 'Check app requirements for user "{{ owner_name }}".'
|
|
ansible.builtin.fail:
|
|
msg: You must set owner name.
|
|
when: not owner_name
|
|
|
|
- name: 'Create group "{{ owner_group }}".'
|
|
ansible.builtin.group:
|
|
name: "{{ owner_group }}"
|
|
state: present
|
|
|
|
- name: 'Create user "{{ owner_name }}".'
|
|
ansible.builtin.user:
|
|
name: "{{ owner_name }}"
|
|
group: "{{ owner_group }}"
|
|
groups: "{{ owner_extra_groups }}"
|
|
shell: /bin/bash
|
|
register: user_create_result
|
|
|
|
- name: 'Set up user ssh keys for user "{{ owner_name }}".'
|
|
ansible.posix.authorized_key:
|
|
user: "{{ owner_name }}"
|
|
key: "{{ item }}"
|
|
state: present
|
|
with_items: "{{ owner_ssh_keys }}"
|
|
when: owner_ssh_keys | length > 0
|
|
|
|
- name: "Prepare env variables."
|
|
ansible.builtin.set_fact:
|
|
env_dict: '{{ owner_env | combine({ "CURRENT_UID": user_create_result.uid | default(owner_name), "CURRENT_GID": user_create_result.group | default(owner_group)
|
|
}) }}'
|
|
|
|
- name: 'Set up environment variables for user "{{ owner_name }}".'
|
|
ansible.builtin.template:
|
|
src: env.j2
|
|
dest: "/home/{{ owner_name }}/.env"
|
|
owner: "{{ owner_name }}"
|
|
group: "{{ owner_group }}"
|
|
mode: "0640"
|
|
|
|
- name: 'Remove from bashrc absent environment variables for user "{{ owner_name }}".'
|
|
ansible.builtin.lineinfile:
|
|
path: "/home/{{ owner_name }}/.bashrc"
|
|
regexp: "^export {{ item.key }}="
|
|
state: absent
|
|
with_dict: "{{ env_dict }}"
|
|
|
|
- name: 'Include in bashrc environment variables for user "{{ owner_name }}".'
|
|
ansible.builtin.lineinfile:
|
|
path: "/home/{{ owner_name }}/.bashrc"
|
|
regexp: "^export \\$\\(grep -v"
|
|
line: 'export $(grep -v "^#" "$HOME"/.env | xargs)'
|