blob: ed9250d829046db4878a81fecdc37eb62bed84ac (
plain) (
tree)
|
|
- name: Upgrade packages or fail gracefully
become: true
block:
- name: Upgrade packages
community.general.pacman:
update_cache: true
upgrade: true
register: pacman_result
notify: reboot
- name: Show upgraded packages
ansible.builtin.debug:
var: pacman_result.packages
when: pacman_result.changed
- name: Flush handlers
ansible.builtin.meta: flush_handlers
rescue:
- name: Fail if /etc is not versioned
ansible.builtin.fail:
msg: Upgrading packages failed for an unknown reason!
when: not etc_versioned
- name: Check for changes in /etc
ansible.builtin.command: git status --porcelain=v1
args:
chdir: /etc
register: git_status
changed_when: false
failed_when: false
- name: Fail if there're no unstaged changes in /etc
ansible.builtin.fail:
msg: Upgrading packages failed for an unknown reason!
when: not git_status.stdout
- name: All changes in /etc are in pacman.d/gnupg?
ansible.builtin.shell: |
set -o pipefail && \
git status --porcelain=v1 \
| cut -c 4- \
| grep -G -v '^pacman.d/gnupg/'
args:
chdir: /etc
register: only_gnupg
changed_when: false
failed_when: false
- name: Commit changes in /etc
ansible.builtin.command: |
etckeeper commit 'pacman: GPG keys'
when: git_status.stdout and only_gnupg.rc != 0
- name: Retry upgrading packages
community.general.pacman:
update_cache: true
upgrade: true
register: pacman_result
notify: reboot
- name: Show upgraded packages
ansible.builtin.debug:
var: pacman_result.packages
when: pacman_result.changed
- name: Flush handlers
ansible.builtin.meta: flush_handlers
|