Files
ansible_role_package/tasks/main.yml
Matthew Stobbs e021d5ebac Modifying default variables and config
Renamed variables for defaults:
- flatpak_method -> default_flatpak_method: system
- defaults.paths.prefix -> default_install_prefix: /usr/local
New variables:
- default_install_method: package
2026-01-24 19:52:56 -07:00

266 lines
6.5 KiB
YAML

# vim: set filetype=yaml.ansible :
---
# create all the facts used throughout the role, but shouldn't be touched
# by the user
- name: Create temporary directory for downloads
register: d_tempdir
ansible.builtin.file:
path: /tmp/ansible_role_package
state: directory
mode: '0777'
- name: Set installation facts
ansible.builtin.include_tasks:
file: facts.yml
- name: Ensure directory exists {{ path.prefix }}
become: "{{ ext_become }}"
ansible.builtin.file:
state: directory
mode: '0755'
path: "{{ path.prefix }}"
- name: Ensure directory exists {{ path.bin }}
become: "{{ ext_become }}"
ansible.builtin.file:
state: directory
mode: '0755'
path: "{{ path.bin }}"
- name: Read default package configuration
ansible.builtin.include_vars:
dir: pkgs
extensions:
- yml
name: pkgconfig
- name: Read default package configuration
ansible.builtin.include_vars:
dir: src
extensions:
- yml
name: srcconfig
- name: Append system_packages to pkg_sys
ansible.builtin.set_fact:
pkg_sys: "{{ pkg_sys + extra_packages }}"
- name: Generate package installation lists
loop: "{{ packages | unique }}"
loop_control:
loop_var: pkg
ansible.builtin.include_tasks:
file: addpkg.yml
- name: Flush handlers to ensure dependencies are installed
ansible.builtin.meta: flush_handlers
- name: Add needed packages for Fedora
when:
- ansible_distribution == 'Fedora'
ansible.builtin.set_fact:
pkg_sys: "{{ pkg_sys + ['python3-paramiko'] }}"
- name: Add needed MacOS packages
when:
- ansible_distribution == 'MacOSX'
ansible.builtin.set_fact:
pkg_sys: "{{ pkg_sys + ['gnu-tar', 'virtualenv'] }}"
- name: Add needed Alpine packages
when:
- ansible_os_family == 'Alpine'
ansible.builtin.set_fact:
pkg_sys: "{{ pkg_sys + ['tar', 'unzip'] }}"
- name: Ensure extra dependencies are installed
block:
- name: Ensure go binary is installed
when: pkg_go|length > 0
vars:
pkg: go
ansible.builtin.include_tasks:
file: addpkg.yml
- name: Ensure go path exists
become: "{{ ext_become }}"
when: pkg_go|length > 0
ansible.builtin.file:
state: directory
mode: '0755'
path: "{{ path.go }}"
- name: Ensure rust and cargo are installed
when: pkg_cargo|length > 0
vars:
pkg: rust
ansible.builtin.include_tasks:
file: addpkg.yml
- name: Ensure pipx is installed
when: pkg_pipx|length > 0
vars:
pkg: pipx
ansible.builtin.include_tasks:
file: addpkg.yml
- name: Ensure pipx path exists
when: pkg_pipx|length > 0
become: "{{ ext_become }}"
ansible.builtin.file:
state: directory
mode: '0755'
path: "{{ path.pipx }}"
- name: Ensure nodejs and npm are installed
when: pkg_npm|length > 0
vars:
pkg: nodejs
ansible.builtin.include_tasks:
file: addpkg.yml
- name: Ensure flatpak is installed
when:
- pkg_flatpak is defined
- pkg_flatpak|length > 0
vars:
pkg: flatpak
ansible.builtin.include_tasks:
file: addpkg.yml
- name: Ensure appimage path exists
when:
- pkg_appimage is defined
- pkg_appimage|length > 0
become: "{{ ext_become }}"
ansible.builtin.file:
state: directory
mode: '0755'
path: "{{ path.appimage }}"
- name: Ensure archive path exists
when: pkg_archive|length > 0
become: "{{ ext_become }}"
ansible.builtin.file:
state: directory
mode: '0755'
path: "{{ path.archive }}"
- name: Depend zig
when: pkg_zig|length > 0
vars:
pkg: zig
ansible.builtin.include_tasks:
file: addpkg.yml
- name: Install sys_pkgs list using system package manager
become: "{{ sys_pkg_become }}"
ansible.builtin.package:
name: "{{ pkg_sys | unique }}"
state: present
- name: Linux specific tasks
when:
- ansible_system == 'Linux'
ansible.builtin.include_tasks:
file: linux.yml
- name: MacOS specific tasks
when:
- ansible_distribution == 'MacOSX'
ansible.builtin.include_tasks:
file: macos.yml
- name: Install pkg_archive
when:
- pkg_archive|length > 0
loop: "{{ pkg_archive }}"
loop_control:
loop_var: pkg
ansible.builtin.include_tasks:
file: "archive/{{ pkg }}.yml"
- name: Install cargo packages
when:
- pkg_cargo|length > 0
block:
- name: Ensure cargo path exists
become: "{{ ext_become }}"
ansible.builtin.file:
state: directory
mode: '0755'
path: "{{ path.cargo }}"
- name: Install cargo packages
loop: "{{ pkg_cargo | unique }}"
loop_control:
loop_var: pkg
ansible.builtin.include_tasks:
file: cargo.yml
- name: Build and install rust apps
when:
- pkg_cargo_build|length > 0
block:
- name: Run cargo build and install
loop: "{{ cargo_pkg_build }}"
loop_control:
loop_var: pkg
vars:
bin_name: "{{ pkg.bin_name | default(omit) }}"
bin_output: "{{ pkg.bin_output | default(omit) }}"
cargo_build_flags: "{{ pkg.cargo_build_flags | default(omit) }}"
depth: "{{ pkg.depth | default(omit) }}"
install_files: "{{ pkg.install_files | default(omit) }}"
name: "{{ pkg.name | default(omit) }}"
recursive: "{{ pkg.recursive | default(omit) }}"
repo: "{{ pkg.repo | default(omit) }}"
ansible.builtin.include_tasks:
file: helpers/cargo_build.yml
- name: Install go packages
when:
- pkg_go|length > 0
block:
- name: Install go pkgs
loop: "{{ pkg_go | unique }}"
loop_control:
loop_var: pkg
ansible.builtin.include_tasks:
file: go.yml
- name: Install local npm packages
when:
- pkg_npm|length > 0
loop: "{{ pkg_npm | unique }}"
loop_control:
loop_var: pkg
ansible.builtin.include_tasks:
file: npm.yml
- name: Install python pipx packages for user
when:
- pkg_pipx|length > 0
loop: "{{ pkg_pipx | unique }}"
loop_control:
loop_var: pkg
ansible.builtin.include_tasks:
file: pipx.yml
- name: Build and install source packages
when:
- pkg_src|length > 0
loop: "{{ pkg_src | unique }}"
loop_control:
loop_var: pkg
ansible.builtin.include_tasks:
file: "src/{{ pkg }}.yml"
- name: Cleanup {{ d_tempdir.path }}
become: true
when:
- not debug
ansible.builtin.file:
state: absent
path: "{{ d_tempdir.path }}"