# 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: Dump packages list debug: var: packages - name: Generate package installation lists loop: "{{ packages | unique }}" loop_control: loop_var: pkg ansible.builtin.include_tasks: file: addpkg.yml - name: End playbook meta: end_play - 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: List pkg_sys to install debug: var: pkg_sys - 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: 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 }} when: - not debug ansible.builtin.file: state: absent path: "{{ d_tempdir.path }}"