Refactor gitea app: deploy with ansible
This commit is contained in:
		| @@ -1,60 +1,52 @@ | ||||
| --- | ||||
| - name: 'Check app requirements for user "{{ owner_name }}".' | ||||
|   fail: | ||||
|   ansible.builtin.fail: | ||||
|     msg: You must set owner name. | ||||
|   when: not owner_name | ||||
|  | ||||
| - name: 'Create group "{{ owner_group }}".' | ||||
|   group: | ||||
|     name: '{{ owner_group }}' | ||||
|   ansible.builtin.group: | ||||
|     name: "{{ owner_group }}" | ||||
|     state: present | ||||
|  | ||||
| - name: 'Create user "{{ owner_name }}".' | ||||
|   user: | ||||
|     name: '{{ owner_name }}' | ||||
|     group: '{{ owner_group }}' | ||||
|     groups: '{{ owner_extra_groups }}' | ||||
|   ansible.builtin.user: | ||||
|     name: "{{ owner_name }}" | ||||
|     group: "{{ owner_group }}" | ||||
|     groups: "{{ owner_extra_groups }}" | ||||
|     shell: /bin/bash | ||||
|   register: uc_result | ||||
|   register: user_create_result | ||||
|  | ||||
| - name: 'Set up user ssh keys for user "{{ owner_name }}".' | ||||
|   authorized_key: | ||||
|     user: '{{ owner_name }}' | ||||
|     key: '{{ item }}' | ||||
|   ansible.posix.authorized_key: | ||||
|     user: "{{ owner_name }}" | ||||
|     key: "{{ item }}" | ||||
|     state: present | ||||
|   with_items: '{{ owner_ssh_keys }}' | ||||
|   with_items: "{{ owner_ssh_keys }}" | ||||
|   when: owner_ssh_keys | length > 0 | ||||
|  | ||||
| - name: 'Prepare env variables.' | ||||
|   set_fact: | ||||
|     env_dict: '{{ owner_env | combine({ | ||||
|       "CURRENT_UID": uc_result.uid | default(owner_name), | ||||
|       "CURRENT_GID": uc_result.group | default(owner_group) }) }}' | ||||
|   tags: | ||||
|     - env | ||||
| - 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 }}".' | ||||
|   template: | ||||
|   ansible.builtin.template: | ||||
|     src: env.j2 | ||||
|     dest: '/home/{{ owner_name }}/.env' | ||||
|     owner: '{{ owner_name }}' | ||||
|     group: '{{ owner_group }}' | ||||
|   tags: | ||||
|     - env | ||||
|     dest: "/home/{{ owner_name }}/.env" | ||||
|     owner: "{{ owner_name }}" | ||||
|     group: "{{ owner_group }}" | ||||
|     mode: "0640" | ||||
|  | ||||
| - name: 'Remove absent environment variables for user "{{ owner_name }}" from bashrc.' | ||||
|   lineinfile: | ||||
|     path: '/home/{{ owner_name }}/.bashrc' | ||||
|     regexp: '^export {{ item.key }}=' | ||||
| - 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 }}' | ||||
|   tags: | ||||
|     - env | ||||
|   with_dict: "{{ env_dict }}" | ||||
|  | ||||
| - name: 'Include environment variables for user "{{ owner_name }}" in bashrc.' | ||||
|   lineinfile: | ||||
|     path: '/home/{{ owner_name }}/.bashrc' | ||||
|     regexp: '^export \$\(grep -v' | ||||
| - 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)' | ||||
|   tags: | ||||
|     - env | ||||
|   | ||||
		Reference in New Issue
	
	Block a user