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:
19
roles/ubuntu/tasks/curl.yml
Normal file
19
roles/ubuntu/tasks/curl.yml
Normal file
@@ -0,0 +1,19 @@
|
||||
---
|
||||
- name: Install starship
|
||||
ansible.builtin.shell: set -o pipefail && curl -fsSL https://starship.rs/install.sh | sh -s -- --yes
|
||||
args:
|
||||
executable: /usr/bin/bash
|
||||
creates: "{{ ansible_env.HOME }}/.config/starship.toml"
|
||||
|
||||
- name: Install Pacstall
|
||||
ansible.builtin.shell: yes | bash -c "$(curl -fsSL https://pacstall.dev/q/install)"
|
||||
args:
|
||||
executable: /usr/bin/bash
|
||||
creates: /usr/local/bin/pacstall
|
||||
become: true
|
||||
|
||||
- name: Install atuin
|
||||
ansible.builtin.shell: set -o pipefail && curl -fsSL https://setup.atuin.sh | sh -s -- --yes
|
||||
args:
|
||||
executable: /usr/bin/bash
|
||||
creates: "{{ ansible_env.HOME }}/.config/atuin"
|
||||
Reference in New Issue
Block a user