add mtail role
This commit is contained in:
67
roles/mtail/tasks/configure.yaml
Normal file
67
roles/mtail/tasks/configure.yaml
Normal file
@ -0,0 +1,67 @@
|
||||
---
|
||||
- name: create group
|
||||
group:
|
||||
name: "{{ mtail_group }}"
|
||||
system: true
|
||||
state: "{{ mtail_group_state | default('present') }}"
|
||||
|
||||
- name: create user
|
||||
user:
|
||||
name: "{{ mtail_user }}"
|
||||
system: true
|
||||
shell: "{{ mtail_user_shell }}"
|
||||
group: "{{ mtail_group }}"
|
||||
groups: "{{ [mtail_group] + (mtail_append_groups | default([])) }}"
|
||||
append: true
|
||||
createhome: false
|
||||
home: "{{ mtail_var_path }}"
|
||||
state: "{{ mtail_user_state | default('present') }}"
|
||||
|
||||
- name: create etc path
|
||||
file:
|
||||
path: "{{ mtail_etc_path }}"
|
||||
state: directory
|
||||
owner: "{{ mtail_etc_owner }}"
|
||||
group: "{{ mtail_etc_group }}"
|
||||
mode: "{{ mtail_etc_mode }}"
|
||||
|
||||
- name: create var path
|
||||
file:
|
||||
path: "{{ mtail_var_path }}"
|
||||
state: directory
|
||||
owner: "{{ mtail_var_owner }}"
|
||||
group: "{{ mtail_var_group }}"
|
||||
mode: "{{ mtail_var_mode }}"
|
||||
|
||||
- name: create var_log path
|
||||
file:
|
||||
path: "{{ mtail_var_log_path }}"
|
||||
state: directory
|
||||
owner: "{{ mtail_var_log_owner }}"
|
||||
group: "{{ mtail_var_log_group }}"
|
||||
mode: "{{ mtail_var_log_mode }}"
|
||||
|
||||
- name: configure rules
|
||||
copy:
|
||||
src: "{{ item }}"
|
||||
dest: "{{ mtail_etc_path }}/{{ item | basename }}"
|
||||
owner: root
|
||||
group: root
|
||||
mode: "0755"
|
||||
loop: "{{ lookup('fileglob', 'rules/*.mtail', wantlist=True) }}"
|
||||
notify: restart mtail
|
||||
|
||||
- name: configure systemd template
|
||||
template:
|
||||
src: mtail.service.j2
|
||||
dest: /etc/systemd/system/mtail.service
|
||||
owner: root
|
||||
group: root
|
||||
mode: 0444
|
||||
notify: restart mtail
|
||||
|
||||
- name: manage service
|
||||
service:
|
||||
name: "{{ mtail_service_name }}"
|
||||
enabled: "{{ mtail_service_enabled }}"
|
||||
state: "{{ mtail_service_state }}"
|
0
roles/mtail/tasks/default.yaml
Normal file
0
roles/mtail/tasks/default.yaml
Normal file
52
roles/mtail/tasks/install.yaml
Normal file
52
roles/mtail/tasks/install.yaml
Normal file
@ -0,0 +1,52 @@
|
||||
---
|
||||
#- block:
|
||||
# - name: download tar
|
||||
# get_url:
|
||||
# url: "{{ mtail_release_url }}"
|
||||
# dest: "{{ mtail_download_path }}"
|
||||
# register: dl
|
||||
# until: dl is success
|
||||
# retries: 5
|
||||
# delay: 10
|
||||
#
|
||||
# - name: install binaries
|
||||
# copy:
|
||||
# src: "{{ mtail_download_path }}"
|
||||
# dest: "{{ mtail_bin_path }}/mtail"
|
||||
# owner: root
|
||||
# group: root
|
||||
# mode: 0755
|
||||
# remote_src: true
|
||||
# notify: restart mtail
|
||||
# when: mtail_version != mtail_local_version
|
||||
#
|
||||
- block:
|
||||
- name: download tar
|
||||
get_url:
|
||||
url: "{{ mtail_release_url }}"
|
||||
dest: "{{ mtail_download_path }}"
|
||||
checksum: "{{ mtail_checksum }}"
|
||||
register: dl
|
||||
until: dl is success
|
||||
retries: 5
|
||||
delay: 10
|
||||
|
||||
- name: extract tar
|
||||
unarchive:
|
||||
src: "{{ mtail_download_path }}"
|
||||
dest: "{{ mtail_unarchive_dest_path }}"
|
||||
creates: "{{ mtail_extracted_path }}/mtail"
|
||||
remote_src: true
|
||||
|
||||
- name: install binaries
|
||||
copy:
|
||||
src: "{{ mtail_extracted_path }}/{{ item }}"
|
||||
dest: "{{ mtail_bin_path }}/{{ item }}"
|
||||
owner: root
|
||||
group: root
|
||||
mode: 0755
|
||||
remote_src: true
|
||||
loop:
|
||||
- mtail
|
||||
notify: restart mtail
|
||||
when: mtail_version != mtail_local_version
|
30
roles/mtail/tasks/main.yaml
Normal file
30
roles/mtail/tasks/main.yaml
Normal file
@ -0,0 +1,30 @@
|
||||
---
|
||||
- name: gather os specific variables
|
||||
include_vars: "{{ lookup('first_found', possible_files) }}"
|
||||
vars:
|
||||
possible_files:
|
||||
files:
|
||||
- "{{ ansible_distribution }}-{{ ansible_distribution_version }}.yaml"
|
||||
- "{{ ansible_distribution }}.yaml"
|
||||
- "{{ ansible_os_family }}.yaml"
|
||||
- "default.yaml"
|
||||
paths:
|
||||
- vars
|
||||
|
||||
- name: include os specific tasks
|
||||
include_tasks: "{{ lookup('first_found', possible_files) }}"
|
||||
vars:
|
||||
possible_files:
|
||||
files:
|
||||
- "{{ ansible_distribution }}-{{ ansible_distribution_version }}.yaml"
|
||||
- "{{ ansible_distribution }}.yaml"
|
||||
- "{{ ansible_os_family }}.yaml"
|
||||
- "default.yaml"
|
||||
paths:
|
||||
- tasks
|
||||
|
||||
- include: pre.yaml
|
||||
|
||||
- include: install.yaml
|
||||
|
||||
- include: configure.yaml
|
88
roles/mtail/tasks/pre.yaml
Normal file
88
roles/mtail/tasks/pre.yaml
Normal file
@ -0,0 +1,88 @@
|
||||
---
|
||||
#- name: determine if installed
|
||||
# stat:
|
||||
# path: "{{ mtail_bin_path }}/mtail"
|
||||
# register: st
|
||||
#
|
||||
#- name: set mtail_installed
|
||||
# set_fact:
|
||||
# mtail_installed: "{{ st.stat.exists | bool }}"
|
||||
#
|
||||
#- block:
|
||||
# - name: determine latest version
|
||||
# uri:
|
||||
# url: https://api.github.com/repos/google/mtail/releases/latest
|
||||
# return_content: true
|
||||
# body_format: json
|
||||
# register: _latest_version
|
||||
# until: _latest_version.status == 200
|
||||
# retries: 3
|
||||
#
|
||||
# - name: set mtail_version
|
||||
# set_fact:
|
||||
# mtail_version: "{{ _latest_version.json['tag_name'] | regex_replace('^v', '') }}"
|
||||
#
|
||||
#- block:
|
||||
# - name: determine installed version
|
||||
# command: "{{ mtail_bin_path }}/mtail --version"
|
||||
# register: _installed_version_string
|
||||
# changed_when: false
|
||||
#
|
||||
# - name: set mtail_local_version
|
||||
# set_fact:
|
||||
# mtail_local_version: "{{ _installed_version_string.stdout | regex_search(mtail_version_regex, '\\1') | first }}"
|
||||
# when: mtail_installed
|
||||
#
|
||||
#- name: set mtail_local_version to 0
|
||||
# set_fact:
|
||||
# mtail_local_version: "0"
|
||||
# when: not mtail_installed
|
||||
- name: determine if installed
|
||||
stat:
|
||||
path: "{{ mtail_bin_path }}/mtail"
|
||||
register: st
|
||||
|
||||
- name: set mtail_installed
|
||||
set_fact:
|
||||
mtail_installed: "{{ st.stat.exists | bool }}"
|
||||
|
||||
- block:
|
||||
- name: determine latest version
|
||||
uri:
|
||||
url: https://api.github.com/repos/google/mtail/releases/latest
|
||||
return_content: true
|
||||
body_format: json
|
||||
register: _latest_version
|
||||
until: _latest_version.status == 200
|
||||
retries: 3
|
||||
|
||||
- name: set mtail_version
|
||||
set_fact:
|
||||
mtail_version: "{{ _latest_version.json['tag_name'] | regex_replace('^v', '') }}"
|
||||
|
||||
- block:
|
||||
- name: determine installed version
|
||||
command: "{{ mtail_bin_path }}/mtail --version"
|
||||
register: _installed_version_string
|
||||
changed_when: false
|
||||
|
||||
- name: set mtail_local_version
|
||||
set_fact:
|
||||
mtail_local_version: "{{ _installed_version_string.stdout | regex_search(mtail_version_regex, '\\1') | first }}"
|
||||
when: mtail_installed
|
||||
|
||||
- name: set mtail_local_version to 0
|
||||
set_fact:
|
||||
mtail_local_version: "0"
|
||||
when: not mtail_installed
|
||||
|
||||
- block:
|
||||
- name: get checksums
|
||||
set_fact:
|
||||
_checksums: "{{ lookup('url', mtail_checksum_url, wantlist=True) }}"
|
||||
|
||||
- name: set mtail_checksum
|
||||
set_fact:
|
||||
mtail_checksum: "sha256:{{ item.split(' ') | first }}"
|
||||
loop: "{{ _checksums }}"
|
||||
when: "mtail_release_file in item"
|
Reference in New Issue
Block a user