mirror of
https://github.com/roles-ansible/ansible_role_restic/
synced 2024-11-08 12:53:30 +01:00
update linting
This commit is contained in:
parent
62b7b7812d
commit
e3732c72c3
9 changed files with 66 additions and 37 deletions
23
.github/workflows/ansible-linting-check.yml
vendored
Normal file
23
.github/workflows/ansible-linting-check.yml
vendored
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
---
|
||||||
|
name: Ansible Lint check
|
||||||
|
|
||||||
|
# yamllint disable-line rule:truthy
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: '*'
|
||||||
|
pull_request:
|
||||||
|
branches: '*'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Lint Ansible Playbook
|
||||||
|
uses: ansible/ansible-lint-action@v6
|
||||||
|
with:
|
||||||
|
targets: "."
|
||||||
|
args: ""
|
8
.github/workflows/galaxy.yml
vendored
8
.github/workflows/galaxy.yml
vendored
|
@ -12,9 +12,11 @@ jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: checkout
|
- name: 'checkout git repo'
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
- name: galaxy
|
|
||||||
uses: robertdebock/galaxy-action@1.2.1
|
- name: 'release on galaxy'
|
||||||
|
uses: robertdebock/galaxy-action@1.2.0
|
||||||
with:
|
with:
|
||||||
galaxy_api_key: ${{ secrets.galaxy_api_key }}
|
galaxy_api_key: ${{ secrets.galaxy_api_key }}
|
||||||
|
git_branch: 'main'
|
||||||
|
|
|
@ -6,14 +6,18 @@ galaxy_info:
|
||||||
license: MIT
|
license: MIT
|
||||||
min_ansible_version: 2.10.6
|
min_ansible_version: 2.10.6
|
||||||
platforms:
|
platforms:
|
||||||
|
- name: ArchLinux
|
||||||
|
versions:
|
||||||
|
- all
|
||||||
- name: Debian
|
- name: Debian
|
||||||
versions: all
|
versions:
|
||||||
- name: EL
|
- all
|
||||||
versions: all
|
|
||||||
- name: Fedora
|
|
||||||
versions: all
|
|
||||||
- name: Ubuntu
|
- name: Ubuntu
|
||||||
versions: all
|
versions:
|
||||||
|
- all
|
||||||
|
- name: Fedora
|
||||||
|
versions:
|
||||||
|
- all
|
||||||
galaxy_tags:
|
galaxy_tags:
|
||||||
- backup
|
- backup
|
||||||
- restic
|
- restic
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
---
|
---
|
||||||
- name: (BACKUP) reformat dict if necessary
|
- name: (BACKUP) reformat dict if necessary
|
||||||
ansible.builtin.set_fact:
|
ansible.builtin.set_fact:
|
||||||
restic_backups: "{{ restic_backups|dict2items|json_query('[*].value') }}"
|
restic_backups: "{{ restic_backups | dict2items | json_query('[*].value') }}"
|
||||||
when:
|
when:
|
||||||
- restic_backups | type_debug == "dict"
|
- restic_backups | type_debug == "dict"
|
||||||
|
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
- not 'config file already exists' in restic_init.stderr
|
- not 'config file already exists' in restic_init.stderr
|
||||||
- not 'config already initialized' in restic_init.stderr
|
- not 'config already initialized' in restic_init.stderr
|
||||||
- not 'config already exists' in restic_init.stderr
|
- not 'config already exists' in restic_init.stderr
|
||||||
loop: "{{ restic_repos|dict2items }}"
|
loop: "{{ restic_repos | dict2items }}"
|
||||||
when:
|
when:
|
||||||
- item.value.init is defined
|
- item.value.init is defined
|
||||||
- item.value.init|bool
|
- item.value.init|bool
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
delegate_to: localhost
|
delegate_to: localhost
|
||||||
|
|
||||||
- name: (SCHEDULE) (OLD) try to remove entries from /etc/crontab
|
- name: (SCHEDULE) (OLD) try to remove entries from /etc/crontab
|
||||||
|
become: true
|
||||||
ansible.builtin.cron:
|
ansible.builtin.cron:
|
||||||
name: "do1jlr.restic backup {{ item.name }}"
|
name: "do1jlr.restic backup {{ item.name }}"
|
||||||
job: "CRON=true {{ restic_script_dir }}/backup-{{ item.name | replace(' ', '') }}.sh"
|
job: "CRON=true {{ restic_script_dir }}/backup-{{ item.name | replace(' ', '') }}.sh"
|
||||||
|
@ -18,7 +19,6 @@
|
||||||
state: absent
|
state: absent
|
||||||
cron_file: '/etc/crontab'
|
cron_file: '/etc/crontab'
|
||||||
user: 'root'
|
user: 'root'
|
||||||
become: true
|
|
||||||
no_log: "{{ restic_no_log }}"
|
no_log: "{{ restic_no_log }}"
|
||||||
with_items: '{{ restic_backups }}'
|
with_items: '{{ restic_backups }}'
|
||||||
when:
|
when:
|
||||||
|
@ -26,11 +26,10 @@
|
||||||
- item.name is defined
|
- item.name is defined
|
||||||
- item.scheduled | default(false)
|
- item.scheduled | default(false)
|
||||||
- ansible_service_mgr != 'systemd' or restic_force_cron | default(false) or restic_schedule_type == "cronjob"
|
- ansible_service_mgr != 'systemd' or restic_force_cron | default(false) or restic_schedule_type == "cronjob"
|
||||||
ignore_error: true
|
|
||||||
tags: skip_ansible_lint
|
|
||||||
register: cron_delete
|
register: cron_delete
|
||||||
|
failed_when: false
|
||||||
|
|
||||||
- name: "(SCHEDULE) (OLD) make sure 'do1jlr.restic backup {{ item.name }}' is not in /etc/crontab"
|
- name: "(SCHEDULE) (OLD) make sure do1jlr.restic backup script is not in /etc/crontab"
|
||||||
become: true
|
become: true
|
||||||
ansible.builtin.lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
path: '/etc/crontab'
|
path: '/etc/crontab'
|
||||||
|
@ -39,7 +38,7 @@
|
||||||
when: cron_delete.failed
|
when: cron_delete.failed
|
||||||
with_items: '{{ restic_backups }}'
|
with_items: '{{ restic_backups }}'
|
||||||
|
|
||||||
- name: "(SCHEDULE) (OLD) make sure '{{ restic_script_dir }}/backup-{{ item.name | replace(' ', '') }}.sh' is not in /etc/crontab"
|
- name: "(SCHEDULE) (OLD) make sure restic script is not in /etc/crontab"
|
||||||
become: true
|
become: true
|
||||||
ansible.builtin.lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
path: '/etc/crontab'
|
path: '/etc/crontab'
|
||||||
|
|
|
@ -1,22 +1,22 @@
|
||||||
---
|
---
|
||||||
- name: add OS specific variables
|
- name: Add OS specific variables
|
||||||
ansible.builtin.include_vars: "{{ lookup('first_found', restic_os_variables) }}"
|
ansible.builtin.include_vars: "{{ lookup('first_found', restic_os_variables) }}"
|
||||||
|
|
||||||
- name: perform optional versionscheck
|
- name: Perform optional versionscheck
|
||||||
ansible.builtin.include_tasks: 'versioncheck.yml'
|
ansible.builtin.include_tasks: 'versioncheck.yml'
|
||||||
when: submodules_versioncheck | bool
|
when: submodules_versioncheck | bool
|
||||||
|
|
||||||
- name: make sure restic is available
|
- name: Make sure restic is available
|
||||||
ansible.builtin.include_tasks: 'preperation.yml'
|
ansible.builtin.include_tasks: 'preperation.yml'
|
||||||
|
|
||||||
- name: make sure restic is installed
|
- name: Make sure restic is installed
|
||||||
ansible.builtin.include_tasks: 'install.yml'
|
ansible.builtin.include_tasks: 'install.yml'
|
||||||
when: not restic_executable.stat.exists or not restic_installed.stat.exists
|
when: not restic_executable.stat.exists or not restic_installed.stat.exists
|
||||||
|
|
||||||
- name: initialize restic repo(s)
|
- name: Initialize restic repo(s)
|
||||||
ansible.builtin.include_tasks: 'configure.yml'
|
ansible.builtin.include_tasks: 'configure.yml'
|
||||||
|
|
||||||
- name: create backup script
|
- name: Create backup script
|
||||||
ansible.builtin.include_tasks: 'backup.yml'
|
ansible.builtin.include_tasks: 'backup.yml'
|
||||||
loop_control:
|
loop_control:
|
||||||
loop_var: loop_distribution
|
loop_var: loop_distribution
|
||||||
|
@ -25,7 +25,7 @@
|
||||||
distribution_version: '{{ ansible_distribution_version }}'
|
distribution_version: '{{ ansible_distribution_version }}'
|
||||||
distribution_major_version: '{{ ansible_distribution_major_version }}'
|
distribution_major_version: '{{ ansible_distribution_major_version }}'
|
||||||
|
|
||||||
- name: schedule restic backup
|
- name: Schedule restic backup
|
||||||
ansible.builtin.include_tasks: 'schedule.yml'
|
ansible.builtin.include_tasks: 'schedule.yml'
|
||||||
loop_control:
|
loop_control:
|
||||||
loop_var: loop_distribution
|
loop_var: loop_distribution
|
||||||
|
|
|
@ -1,5 +1,9 @@
|
||||||
---
|
---
|
||||||
- name: (SCHEDULE) (SYSTEMD) create systemd timer
|
- name: (SCHEDULE) (SYSTEMD) create systemd timer
|
||||||
|
when:
|
||||||
|
- ansible_service_mgr == 'systemd'
|
||||||
|
- restic_schedule_type == "systemd"
|
||||||
|
- restic_create_schedule | bool
|
||||||
block:
|
block:
|
||||||
- name: (SCHEDULE) (SYSTEMD) copy systemd timer
|
- name: (SCHEDULE) (SYSTEMD) copy systemd timer
|
||||||
become: true
|
become: true
|
||||||
|
@ -56,11 +60,7 @@
|
||||||
when:
|
when:
|
||||||
- item.name is defined
|
- item.name is defined
|
||||||
- item.scheduled | default(false)
|
- item.scheduled | default(false)
|
||||||
when:
|
|
||||||
- ansible_service_mgr == 'systemd'
|
|
||||||
- restic_schedule_type == "systemd"
|
|
||||||
- restic_create_schedule | bool
|
|
||||||
rescue:
|
rescue:
|
||||||
- name: set cronjob intead of systemd
|
- name: Set cronjob intead of systemd
|
||||||
ansible.builtin.set_fact:
|
ansible.builtin.set_fact:
|
||||||
restic_force_cron: true
|
restic_force_cron: true
|
||||||
|
|
|
@ -8,37 +8,38 @@
|
||||||
path: '/etc/.ansible-version'
|
path: '/etc/.ansible-version'
|
||||||
state: directory
|
state: directory
|
||||||
mode: 0755
|
mode: 0755
|
||||||
when: submodules_versioncheck|bool
|
when: submodules_versioncheck | bool
|
||||||
|
|
||||||
- name: check playbook version
|
- name: Check playbook version
|
||||||
become: true
|
become: true
|
||||||
ansible.builtin.slurp:
|
ansible.builtin.slurp:
|
||||||
src: "/etc/.ansible-version/{{ playbook_version_path }}"
|
src: "/etc/.ansible-version/{{ playbook_version_path }}"
|
||||||
register: playbook_version
|
register: playbook_version
|
||||||
when: submodules_versioncheck|bool
|
when: submodules_versioncheck | bool
|
||||||
ignore_errors: true
|
ignore_errors: true
|
||||||
failed_when: false
|
failed_when: false
|
||||||
|
|
||||||
- name: Print remote role version
|
- name: Print remote role version
|
||||||
ansible.builtin.debug:
|
ansible.builtin.debug:
|
||||||
msg: "Remote role version: {{ playbook_version.content | default('Y3VycmVudGx5IG5vdCBkZXBsb3llZAo=') | b64decode | string }}"
|
msg: "Remote role version: {{ playbook_version.content | default('Y3VycmVudGx5IG5vdCBkZXBsb3llZAo=') | b64decode | string }}"
|
||||||
when: submodules_versioncheck|bool
|
when: submodules_versioncheck | bool
|
||||||
|
|
||||||
- name: Print locale role version
|
- name: Print locale role version
|
||||||
ansible.builtin.debug:
|
ansible.builtin.debug:
|
||||||
msg: "Local role version: '{{ playbook_version_number|string }}'."
|
msg: "Local role version: '{{ playbook_version_number | string }}'."
|
||||||
when: submodules_versioncheck|bool
|
when: submodules_versioncheck | bool
|
||||||
|
|
||||||
- name: Check if your version is outdated
|
- name: Check if your version is outdated
|
||||||
ansible.builtin.fail:
|
ansible.builtin.fail:
|
||||||
msg: "Your ansible module has the version '{{ playbook_version_number }}' and is outdated. You need to update it!"
|
msg: "Your ansible module has the version '{{ playbook_version_number }}' and is outdated. You need to update it!"
|
||||||
when:
|
when:
|
||||||
- playbook_version.content|default("Mgo=")|b64decode|int - 1 >= playbook_version_number|int and submodules_versioncheck|bool
|
- playbook_version.content | default("Mgo=") | b64decode | int - 1 >= playbook_version_number | int and submodules_versioncheck | bool
|
||||||
|
|
||||||
- name: write new version to remote disk
|
- name: Write new version to remote disk
|
||||||
become: true
|
become: true
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
content: "{{ playbook_version_number }}"
|
content: "{{ playbook_version_number }}"
|
||||||
dest: "/etc/.ansible-version/{{ playbook_version_path }}"
|
dest: "/etc/.ansible-version/{{ playbook_version_path }}"
|
||||||
mode: '0644'
|
mode: '0644'
|
||||||
when: submodules_versioncheck|bool
|
when: submodules_versioncheck | bool
|
||||||
|
tags: skip_ansible_lint_rule_template-instead-of-copy
|
||||||
|
|
Loading…
Reference in a new issue