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>
This commit is contained in:
35
roles/ubuntu/tasks/git_deb.yml
Normal file
35
roles/ubuntu/tasks/git_deb.yml
Normal file
@@ -0,0 +1,35 @@
|
||||
---
|
||||
- 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
|
||||
Reference in New Issue
Block a user