Split role from infra repo
This commit is contained in:
commit
666e7a9ae1
38
README.md
Normal file
38
README.md
Normal file
@ -0,0 +1,38 @@
|
||||
compose_project
|
||||
=========
|
||||
|
||||
Helps you deploy and update a remote docker-compose project.
|
||||
|
||||
Requirements
|
||||
------------
|
||||
|
||||
Any pre-requisites that may not be covered by Ansible itself or the role should be mentioned here. For instance, if the role uses the EC2 module, it may be a good idea to mention in this section that the boto package is required.
|
||||
|
||||
Role Variables
|
||||
--------------
|
||||
|
||||
`service`: name of the service to be deployed. Currently part of the role templates.
|
||||
|
||||
`compose_dir`: Directory which contains all compose services on the target
|
||||
|
||||
Dependencies
|
||||
------------
|
||||
|
||||
|
||||
Example Playbook
|
||||
----------------
|
||||
|
||||
Including an example of how to use your role (for instance, with variables passed in as parameters) is always nice for users too:
|
||||
|
||||
- hosts: servers
|
||||
roles:
|
||||
- { role: compose_project, service: traefik }
|
||||
- { role: compose_project, service: nextcloud }
|
||||
|
||||
License
|
||||
-------
|
||||
|
||||
MIT
|
||||
|
||||
Author Information
|
||||
------------------
|
6
defaults/main.yml
Normal file
6
defaults/main.yml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
# defaults file for roles/compose_project
|
||||
service: dummy
|
||||
compose_dir: /home/core/compose
|
||||
state: present # or absent
|
||||
restart: smart # or always or never
|
2
handlers/main.yml
Normal file
2
handlers/main.yml
Normal file
@ -0,0 +1,2 @@
|
||||
---
|
||||
# handlers file for roles/compose_project
|
52
meta/main.yml
Normal file
52
meta/main.yml
Normal file
@ -0,0 +1,52 @@
|
||||
galaxy_info:
|
||||
author: Tobias Manske
|
||||
description: Deploys a docker compose directory and restarts on change
|
||||
company: null
|
||||
|
||||
# If the issue tracker for your role is not on github, uncomment the
|
||||
# next line and provide a value
|
||||
# issue_tracker_url: http://example.com/issue/tracker
|
||||
|
||||
# Choose a valid license ID from https://spdx.org - some suggested licenses:
|
||||
# - BSD-3-Clause (default)
|
||||
# - MIT
|
||||
# - GPL-2.0-or-later
|
||||
# - GPL-3.0-only
|
||||
# - Apache-2.0
|
||||
# - CC-BY-4.0
|
||||
license: MIT
|
||||
|
||||
min_ansible_version: 2.1
|
||||
|
||||
# If this a Container Enabled role, provide the minimum Ansible Container version.
|
||||
# min_ansible_container_version:
|
||||
|
||||
#
|
||||
# Provide a list of supported platforms, and for each platform a list of versions.
|
||||
# If you don't wish to enumerate all versions for a particular platform, use 'all'.
|
||||
# To view available platforms and versions (or releases), visit:
|
||||
# https://galaxy.ansible.com/api/v1/platforms/
|
||||
#
|
||||
# platforms:
|
||||
# - name: Fedora
|
||||
# versions:
|
||||
# - all
|
||||
# - 25
|
||||
# - name: SomePlatform
|
||||
# versions:
|
||||
# - all
|
||||
# - 1.0
|
||||
# - 7
|
||||
# - 99.99
|
||||
|
||||
galaxy_tags: []
|
||||
# List tags for your role here, one per line. A tag is a keyword that describes
|
||||
# and categorizes the role. Users find roles by searching for tags. Be sure to
|
||||
# remove the '[]' above, if you add tags to this list.
|
||||
#
|
||||
# NOTE: A tag is limited to a single word comprised of alphanumeric characters.
|
||||
# Maximum 20 tags per role.
|
||||
|
||||
dependencies: []
|
||||
# List your role dependencies here, one per line. Be sure to remove the '[]' above,
|
||||
# if you add dependencies to this list.
|
68
tasks/create.yml
Normal file
68
tasks/create.yml
Normal file
@ -0,0 +1,68 @@
|
||||
---
|
||||
|
||||
- block:
|
||||
- name: Create Temporary directory
|
||||
tempfile:
|
||||
state: directory
|
||||
changed_when: false
|
||||
register: temp_file
|
||||
- name: Create directory structure
|
||||
file:
|
||||
state: directory
|
||||
dest: '{{ temp_file.path }}/{{ item.path }}'
|
||||
mode: "{{ item.mode }}"
|
||||
changed_when: false
|
||||
with_filetree: "./templates/{{ service | mandatory }}"
|
||||
when: item.state == 'directory'
|
||||
loop_control:
|
||||
label: '{{ item.path }}'
|
||||
- name: Template Service Files
|
||||
ansible.builtin.template:
|
||||
src: "{{ item.src }}"
|
||||
dest: "{{ temp_file.path }}/{{ item.path }}"
|
||||
mode: "{{ item.mode }}"
|
||||
force: true
|
||||
trim_blocks: false
|
||||
changed_when: false
|
||||
with_filetree: "./templates/{{ service | mandatory }}"
|
||||
loop_control:
|
||||
label: '{{ item.path }}'
|
||||
when: item.state == 'file'
|
||||
delegate_to: localhost
|
||||
check_mode: no
|
||||
|
||||
- name: Create Service Directory
|
||||
file:
|
||||
state: directory
|
||||
path: "{{ compose_dir | mandatory }}"
|
||||
|
||||
- name: Copy Compose files
|
||||
become: false
|
||||
ansible.posix.synchronize:
|
||||
src: "{{ temp_file.path | mandatory }}/"
|
||||
dest: "{{ service_dir | mandatory }}"
|
||||
archive: false
|
||||
checksum: true
|
||||
delete: true
|
||||
recursive: true
|
||||
mode: push
|
||||
owner: false
|
||||
group: false
|
||||
perms: false
|
||||
register: compose_files
|
||||
|
||||
- name: Delete temporary directory
|
||||
ansible.builtin.file:
|
||||
path: "{{ temp_file.path }}"
|
||||
state: absent
|
||||
changed_when: false
|
||||
|
||||
- name: Restart Service
|
||||
community.docker.docker_compose:
|
||||
project_src: "{{ service_dir | mandatory }}"
|
||||
state: present
|
||||
restarted: true
|
||||
recreate: smart
|
||||
build: true
|
||||
remove_orphans: true
|
||||
when: (compose_files.changed and restart == "smart") or restart == "always"
|
18
tasks/main.yml
Normal file
18
tasks/main.yml
Normal file
@ -0,0 +1,18 @@
|
||||
---
|
||||
|
||||
- name: Set service_dir
|
||||
ansible.builtin.set_fact:
|
||||
service_dir: "{{ compose_dir | mandatory }}/{{ service | mandatory }}{% if service_name is defined %}-{{ service_name }}{% endif %}"
|
||||
cacheable: true
|
||||
|
||||
- ansible.builtin.debug:
|
||||
msg: "Working on {{ service }}{% if service_name is defined %}-{{ service_name }}{% endif %}"
|
||||
verbosity: 0
|
||||
|
||||
- include_tasks: create.yml
|
||||
when: state == "present"
|
||||
|
||||
- include_tasks: remove.yml
|
||||
when: state == "absent"
|
||||
|
||||
...
|
18
tasks/remove.yml
Normal file
18
tasks/remove.yml
Normal file
@ -0,0 +1,18 @@
|
||||
---
|
||||
- name: Check if service is present
|
||||
stat:
|
||||
path: "{{ service_dir | mandatory }}"
|
||||
register: dir
|
||||
|
||||
- name: Stop Service
|
||||
community.docker.docker_compose:
|
||||
project_src: "{{ service_dir | mandatory }}"
|
||||
state: absent
|
||||
remove_orphans: true
|
||||
when: dir.stat.exists == True
|
||||
|
||||
- name: Remove Service
|
||||
file:
|
||||
state: absent
|
||||
path: "{{ service_dir | mandatory }}"
|
||||
when: dir.stat.exists == True
|
2
tests/inventory
Normal file
2
tests/inventory
Normal file
@ -0,0 +1,2 @@
|
||||
localhost
|
||||
|
5
tests/test.yml
Normal file
5
tests/test.yml
Normal file
@ -0,0 +1,5 @@
|
||||
---
|
||||
- hosts: localhost
|
||||
remote_user: root
|
||||
roles:
|
||||
- roles/compose_project
|
2
vars/main.yml
Normal file
2
vars/main.yml
Normal file
@ -0,0 +1,2 @@
|
||||
---
|
||||
# vars file for roles/compose_project
|
Loading…
Reference in New Issue
Block a user