131 lines
5.1 KiB
YAML
131 lines
5.1 KiB
YAML
# Ansible Roles for managing Auengun.net Infrastructure & Testing/Learning.
|
|
# Source available at git.auengun.net/homelab/ansible-collection
|
|
# Copyright (C) 2023 GregoryDosh
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
# License, or (at your option) any later version.
|
|
|
|
# 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 Affero General Public License for more details.
|
|
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
# SPDX-FileCopyrightText: 2023 GregoryDosh
|
|
---
|
|
- name: Template env into place
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ role_path }}/templates/env.j2"
|
|
dest: "{{ DCAASS_CONFIG_PATH }}/{{ DCAASS_ENV_FILE_NAME }}"
|
|
owner: "{{ DCAASS_CONFIG_USER_NAME }}"
|
|
group: "{{ DCAASS_CONFIG_GROUP_NAME }}"
|
|
mode: "{{ DCAASS_CONFIG_FILE_MODE }}"
|
|
register: _dcaass_env_template
|
|
notify:
|
|
- "Restart DCaaSS"
|
|
|
|
- name: Template `docker-compose.yml` into place
|
|
become: true
|
|
ansible.builtin.copy:
|
|
content: "{{ DCAASS_DOCKER_COMPOSE | to_nice_yaml(indent=2, width=999999) }}"
|
|
dest: "{{ DCAASS_CONFIG_PATH }}/docker-compose.yml"
|
|
owner: "{{ DCAASS_CONFIG_USER_NAME }}"
|
|
group: "{{ DCAASS_CONFIG_GROUP_NAME }}"
|
|
mode: "{{ DCAASS_CONFIG_FILE_MODE }}"
|
|
register: _dcaass_docker_compose_template
|
|
notify:
|
|
- "Restart DCaaSS"
|
|
|
|
- name: Template extra configuration files into place
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ item.src }}"
|
|
dest: "{{ item.dest }}"
|
|
owner: "{{ item['owner'] if 'owner' in item.keys() else DCAASS_CONFIG_USER_NAME }}"
|
|
group: "{{ item['group'] if 'group' in item.keys() else DCAASS_CONFIG_GROUP_NAME }}"
|
|
mode: "{{ item['mode'] if 'mode' in item else DCAASS_CONFIG_FILE_MODE }}"
|
|
register: _dcaass_extra_files
|
|
with_items: "{{ DCAASS_EXTRA_CONFIG_FILES }}"
|
|
notify:
|
|
- "Restart DCaaSS"
|
|
|
|
- name: Pull `docker-compose.yml` images
|
|
when: DCAASS_DOCKER_COMPOSE_PULL_INITIAL_IMAGES | bool
|
|
become: true
|
|
ansible.builtin.shell: |
|
|
{{ DOCKER_BIN_ABSOLUTE_PATH }}{{ DCAASS_DOCKER_COMPOSE_SEPARATOR }}compose -f "{{ DCAASS_CONFIG_PATH }}/docker-compose.yml" pull
|
|
changed_when: false
|
|
|
|
- name: Build `docker-compose.yml` images
|
|
when: DCAASS_DOCKER_COMPOSE_BUILD_INITIAL_IMAGES | bool
|
|
become: true
|
|
ansible.builtin.shell: |
|
|
{{ DOCKER_BIN_ABSOLUTE_PATH }}{{ DCAASS_DOCKER_COMPOSE_SEPARATOR }}compose -f "{{ DCAASS_CONFIG_PATH }}/docker-compose.yml" build
|
|
changed_when: false
|
|
|
|
- name: Template DCaaSS systemd service into place
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ role_path }}/templates/etc/systemd/system/dcaass.service.j2"
|
|
dest: "/etc/systemd/system/{{ DCAASS_SERVICE_NAME }}.service"
|
|
owner: "{{ DCAASS_SERVICE_USER_NAME }}"
|
|
group: "{{ DCAASS_SERVICE_GROUP_NAME }}"
|
|
mode: "0644"
|
|
register: _dcaass_service_template
|
|
notify:
|
|
- "Restart DCaaSS"
|
|
|
|
- name: Template Docker Prune systemd service into place
|
|
when: DCAASS_DOCKER_PRUNE_SERVICE_INSTALL | bool
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ role_path }}/templates/etc/systemd/system/dcaass_prune.service.j2"
|
|
dest: "/etc/systemd/system/{{ DCAASS_DOCKER_PRUNE_SERVICE_NAME }}.service"
|
|
owner: "{{ DCAASS_DOCKER_PRUNE_SERVICE_USER_NAME }}"
|
|
group: "{{ DCAASS_DOCKER_PRUNE_SERVICE_GROUP_NAME }}"
|
|
mode: "0644"
|
|
register: _dcaass_docker_prune_service_template
|
|
|
|
- name: Template Docker Prune systemd timer into place
|
|
when: DCAASS_DOCKER_PRUNE_SERVICE_INSTALL | bool
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ role_path }}/templates/etc/systemd/system/dcaass_prune.timer.j2"
|
|
dest: "/etc/systemd/system/{{ DCAASS_DOCKER_PRUNE_SERVICE_NAME }}.timer"
|
|
owner: "{{ DCAASS_DOCKER_PRUNE_SERVICE_USER_NAME }}"
|
|
group: "{{ DCAASS_DOCKER_PRUNE_SERVICE_GROUP_NAME }}"
|
|
mode: "0644"
|
|
register: _dcaass_docker_prune_timer_template
|
|
|
|
- name: Force systemd daemon reload
|
|
when: (_dcaass_service_template.changed or _dcaass_docker_compose_template.changed or _dcaass_env_template.changed or _dcaass_docker_prune_service_template.changed or _dcaass_docker_prune_timer_template.changed or _dcaass_extra_files.changed) and (DCAASS_SERVICE_ANSIBLE_ALLOW_RESTART | bool)
|
|
become: true
|
|
ansible.builtin.systemd_service:
|
|
daemon_reload: true
|
|
|
|
- name: enable DCaaSS service
|
|
become: true
|
|
ansible.builtin.systemd_service:
|
|
name: "{{ DCAASS_SERVICE_NAME }}.service"
|
|
enabled: true
|
|
|
|
- name: enable Docker Prune service
|
|
become: true
|
|
when: DCAASS_DOCKER_PRUNE_SERVICE_INSTALL | bool
|
|
ansible.builtin.systemd_service:
|
|
name: "{{ DCAASS_DOCKER_PRUNE_SERVICE_NAME }}.service"
|
|
enabled: true
|
|
|
|
- name: enable Docker Prune timer
|
|
become: true
|
|
when: DCAASS_DOCKER_PRUNE_SERVICE_INSTALL | bool
|
|
ansible.builtin.systemd_service:
|
|
name: "{{ DCAASS_DOCKER_PRUNE_SERVICE_NAME }}.timer"
|
|
state: started
|
|
enabled: true
|