--- # Tasks file for the gitlab role # Infrastructure # Ansible instructions to deploy the infrastructure # Copyright (C) 2019-2020 Christoph (Sheogorath) Kern # Copyright (C) 2020 Saibotk # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, version 3 of the License. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . - name: Update default SELinux contexts community.general.sefcontext: target: "{{ item }}(/.*)?" setype: "container_file_t" state: present with_items: - "{{ gitlab_data_location }}" - "{{ gitlab_config_location }}" - "{{ gitlab_log_location }}" - "{{ gitlab_telegraf_location }}" tags: - gitlab when: - gitlab_selinux_enabled become: true - name: Create install directory ansible.builtin.file: path: "{{ item }}" state: directory mode: "0700" owner: "root" group: "root" with_items: - "{{ gitlab_install_location }}" tags: - gitlab become: true - name: Create data directory ansible.builtin.file: # noqa risky-file-permissions # Container manages permissions on its own path: "{{ item }}" state: directory owner: "root" group: "root" setype: "container_file_t" with_items: - "{{ gitlab_data_location }}" - "{{ gitlab_config_location }}" - "{{ gitlab_log_location }}" - "{{ gitlab_telegraf_location }}" tags: - gitlab become: true - name: Deploy telegraf.conf ansible.builtin.template: src: telegraf.conf dest: "{{ gitlab_telegraf_location }}/telegraf.conf" mode: "0600" owner: "root" group: "root" tags: - telegraf - gitlab become: true when: - gitlab_telegraf.enabled - name: Deploy docker-compose.yml ansible.builtin.template: src: docker-compose.yml dest: "{{ gitlab_install_location }}/docker-compose.yml" mode: "0600" owner: "root" group: "root" validate: docker compose -f %s config -q tags: - docker - gitlab become: true - name: Compose GitLab community.docker.docker_compose_v2: state: present project_src: "{{ gitlab_install_location }}" pull: always remove_orphans: true tags: - gitlab become: true