Files
ansible/roles/ubuntu/tasks/git_deb.yml
Tuan-Dat Tran 39a2925bcd feat(ubuntu): Refactor package installation, streamline GitHub deb installs
- Added 'become_password_file' to 'ansible.cfg' for privilege escalation handling.
- Removed separate installation tasks for 'atuin', 'eurkey', 'ghostty', 'git-delta', 'ripgrep', 'starship', 'veracrypt', and 'pacstall', consolidating them into 'curl.yml' and 'git_deb.yml'.
- Introduced 'git_deb.yml' for handling GitHub '.deb' installations dynamically using 'github_deb' variable.
- Improved error handling and pipe safety in curl-based installations ('set -o pipefail').
- Set proper permissions ('mode: 0600') for downloaded files in 'remove_ubuntu_banner.yml' and 'fira_code_fonts.yml'.
- Refactored 'github_releases.yml' to allow optional 'v' prefix handling in 'tag_name'.
- Updated 'main.yml' to remove redundant installations and streamline execution.
- Defined 'github_deb' list in 'vars/main.yml' to manage '.deb' package downloads dynamically.

These changes enhance maintainability, reduce redundancy, and improve package installation flexibility.

Signed-off-by: Tuan-Dat Tran <tuan-dat.tran@tudattr.dev>
2025-02-17 18:19:08 +01:00

36 lines
1.0 KiB
YAML

---
- name: "Get latest version: {{ project.name }}"
ansible.builtin.shell: |
set -o pipefail && curl -s "https://api.github.com/repos/{{ project.repo }}/releases/latest" |
grep -Po '"tag_name": *"(VeraCrypt_|v)?\K[^"]*'
args:
executable: /usr/bin/bash
register: project_version
changed_when: false
when: (project.repo | length > 0) and not item.skip
- name: "Set version: {{ project_version }}"
ansible.builtin.set_fact:
project_version: "{{ project_version.stdout }}"
when: (project.repo | length > 0) and not item.skip
- name: "Download deb: {{ project.name }}"
ansible.builtin.get_url:
url: "{{ project.url | replace(project_version_placeholder, project_version) }}"
dest: "/tmp/{{ project.name }}.deb"
mode: "0666"
when: not item.skip
- name: Install {{ project.name }}
ansible.builtin.apt:
deb: "/tmp/{{ project.name }}.deb"
state: present
become: true
when: not item.skip
- name: Remove deb
ansible.builtin.file:
path: "/tmp/{{ project.name }}.deb"
state: absent
when: not item.skip