Add support for Fedora to various roles
This commit is contained in:
parent
8ef426139b
commit
b560f9c7d9
4
playbooks/1password.yaml
Normal file
4
playbooks/1password.yaml
Normal file
@ -0,0 +1,4 @@
|
||||
---
|
||||
- hosts: localhost
|
||||
roles:
|
||||
- 1password
|
22
roles/1password/tasks/RedHat.yaml
Normal file
22
roles/1password/tasks/RedHat.yaml
Normal file
@ -0,0 +1,22 @@
|
||||
---
|
||||
- name: add yum repository key
|
||||
become: true
|
||||
rpm_key:
|
||||
key: https://downloads.1password.com/linux/keys/1password.asc
|
||||
|
||||
- name: add yum repository
|
||||
become: true
|
||||
yum_repository:
|
||||
name: 1password
|
||||
description: 1Password Stable Channel
|
||||
baseurl: https://downloads.1password.com/linux/rpm/stable/$basearch
|
||||
enabled: true
|
||||
gpgcheck: true
|
||||
repo_gpgcheck: true
|
||||
gpgkey: ['https://downloads.1password.com/linux/keys/1password.asc']
|
||||
|
||||
- name: install yum package
|
||||
become: true
|
||||
yum:
|
||||
name: 1password
|
||||
state: latest
|
6
roles/ag/tasks/RedHat.yaml
Normal file
6
roles/ag/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install yum package
|
||||
become: true
|
||||
yum:
|
||||
name: the_silver_searcher
|
||||
state: latest
|
@ -4,7 +4,6 @@
|
||||
ansible_distribution == "Ubuntu" and
|
||||
ansible_distribution_version == "18.04"
|
||||
}}'
|
||||
- debug: msg={{use_github}}
|
||||
|
||||
- when: use_github
|
||||
include_tasks: deb.yaml
|
||||
|
6
roles/bat/tasks/RedHat.yaml
Normal file
6
roles/bat/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install yum package
|
||||
become: true
|
||||
yum:
|
||||
name: bat
|
||||
state: latest
|
6
roles/curl/tasks/RedHat.yaml
Normal file
6
roles/curl/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install yum package
|
||||
become: true
|
||||
yum:
|
||||
name: curl
|
||||
state: latest
|
6
roles/fzf/tasks/RedHat.yaml
Normal file
6
roles/fzf/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install yum package
|
||||
become: true
|
||||
yum:
|
||||
name: fzf
|
||||
state: latest
|
12
roles/gh/tasks/RedHat.yaml
Normal file
12
roles/gh/tasks/RedHat.yaml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
- name: add yum repository
|
||||
become: true
|
||||
get_url:
|
||||
url: https://cli.github.com/packages/rpm/gh-cli.repo
|
||||
dest: /etc/yum.repos.d/gh-cli.repo
|
||||
|
||||
- name: install dnf package
|
||||
become: true
|
||||
dnf:
|
||||
name: gh
|
||||
state: latest
|
6
roles/htop/tasks/RedHat.yaml
Normal file
6
roles/htop/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install dnf package
|
||||
become: true
|
||||
dnf:
|
||||
name: htop
|
||||
state: latest
|
51
roles/jp/tasks/RedHat.yaml
Normal file
51
roles/jp/tasks/RedHat.yaml
Normal file
@ -0,0 +1,51 @@
|
||||
---
|
||||
- name: stat executable
|
||||
stat:
|
||||
path: '{{ansible_env.HOME}}/.local/bin/jp'
|
||||
register: jp_stat
|
||||
|
||||
- name: get installed version
|
||||
when: jp_stat.stat.exists
|
||||
command: jp --version
|
||||
changed_when: false
|
||||
register: jp_version
|
||||
|
||||
- name: extract installed version
|
||||
when: jp_stat.stat.exists
|
||||
set_fact:
|
||||
jp_installed_version:
|
||||
'{{jp_version.stdout.strip() | regex_replace("^.*(\d+\.\d+\.\d+).*$", "\1")}}'
|
||||
|
||||
- name: get latest release
|
||||
uri:
|
||||
url: 'https://api.github.com/repos/jmespath/jp/releases/latest'
|
||||
register: latest
|
||||
|
||||
- name: determine if jp needs installed
|
||||
set_fact:
|
||||
jp_needs_installed:
|
||||
'{{not jp_stat.stat.exists or jp_installed_version != latest.json.tag_name}}'
|
||||
arch_dict: {x86_64: amd64, arm64: arm64}
|
||||
|
||||
- name: select asset name
|
||||
when: jp_needs_installed
|
||||
set_fact:
|
||||
asset_query:
|
||||
'[?contains(name, `jp-linux-{{arch_dict[ansible_architecture]}}`)] | [0]'
|
||||
- name: select asset
|
||||
when: jp_needs_installed
|
||||
set_fact:
|
||||
asset: '{{latest.json.assets | to_json | from_json | json_query(asset_query)}}'
|
||||
|
||||
- name: create directory
|
||||
when: jp_needs_installed
|
||||
file:
|
||||
path: '{{ansible_env.HOME}}/.local/bin'
|
||||
state: directory
|
||||
|
||||
- name: install executable
|
||||
when: jp_needs_installed
|
||||
get_url:
|
||||
url: '{{asset.browser_download_url}}'
|
||||
dest: '{{ansible_env.HOME}}/.local/bin/jp'
|
||||
mode: '0755'
|
6
roles/jq/tasks/RedHat.yaml
Normal file
6
roles/jq/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install dnf package
|
||||
become: true
|
||||
dnf:
|
||||
name: jq
|
||||
state: latest
|
10
roles/llvm/tasks/Fedora.yaml
Normal file
10
roles/llvm/tasks/Fedora.yaml
Normal file
@ -0,0 +1,10 @@
|
||||
---
|
||||
- name: install dnf packages
|
||||
become: true
|
||||
dnf:
|
||||
name:
|
||||
- clang
|
||||
- clang-tools-extra
|
||||
- git-clang-format
|
||||
- llvm
|
||||
state: latest
|
8
roles/neovim/tasks/RedHat.yaml
Normal file
8
roles/neovim/tasks/RedHat.yaml
Normal file
@ -0,0 +1,8 @@
|
||||
---
|
||||
- name: install yum package
|
||||
become: true
|
||||
yum:
|
||||
name: neovim
|
||||
state: latest
|
||||
|
||||
- include_tasks: Unix.yaml
|
6
roles/nodejs/tasks/RedHat.yaml
Normal file
6
roles/nodejs/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install yum package
|
||||
become: true
|
||||
yum:
|
||||
name: nodejs
|
||||
state: latest
|
@ -8,3 +8,4 @@
|
||||
- python3-pip
|
||||
- python3-venv
|
||||
- python3-virtualenv
|
||||
state: latest
|
||||
|
9
roles/python/tasks/RedHat.yaml
Normal file
9
roles/python/tasks/RedHat.yaml
Normal file
@ -0,0 +1,9 @@
|
||||
---
|
||||
- name: install yum packages
|
||||
become: true
|
||||
yum:
|
||||
name:
|
||||
- python3
|
||||
- python3-pip
|
||||
- python3-virtualenv
|
||||
state: latest
|
3
roles/sudo/vars/RedHat.yaml
Normal file
3
roles/sudo/vars/RedHat.yaml
Normal file
@ -0,0 +1,3 @@
|
||||
---
|
||||
sudo_owner: root
|
||||
sudo_group: wheel
|
@ -3,34 +3,10 @@
|
||||
become: true
|
||||
apt:
|
||||
name:
|
||||
- acpi
|
||||
- gawk
|
||||
- lm-sensors
|
||||
- sysstat
|
||||
state: latest
|
||||
|
||||
- name: create systemd user unit directory
|
||||
file:
|
||||
state: directory
|
||||
dest: ~/.config/systemd/user
|
||||
|
||||
- set_fact:
|
||||
SYSTEM_INFO_SCRIPT_DIR: '{{ansible_env.HOME}}/.config/tmux/system-info'
|
||||
|
||||
- when: '"WSL" not in ansible_kernel'
|
||||
set_fact:
|
||||
SYSTEM_INFO_SCRIPT: '{{SYSTEM_INFO_SCRIPT_DIR}}/system-info-Linux.sh'
|
||||
- when: '"WSL" in ansible_kernel'
|
||||
set_fact:
|
||||
SYSTEM_INFO_SCRIPT: '{{SYSTEM_INFO_SCRIPT_DIR}}/system-info-WSL.sh'
|
||||
|
||||
- name: install system-info systemd unit
|
||||
template:
|
||||
src: templates/system-info.service.j2
|
||||
dest: ~/.config/systemd/user/system-info.service
|
||||
notify: restart system-info
|
||||
|
||||
- name: enable system-info service
|
||||
systemd:
|
||||
name: system-info
|
||||
scope: user
|
||||
enabled: true
|
||||
state: started
|
||||
- include_tasks: Linux.yaml
|
||||
|
28
roles/system-info/tasks/Linux.yaml
Normal file
28
roles/system-info/tasks/Linux.yaml
Normal file
@ -0,0 +1,28 @@
|
||||
---
|
||||
- name: create systemd user unit directory
|
||||
file:
|
||||
state: directory
|
||||
dest: ~/.config/systemd/user
|
||||
|
||||
- set_fact:
|
||||
SYSTEM_INFO_SCRIPT_DIR: '{{ansible_env.HOME}}/.config/tmux/system-info'
|
||||
|
||||
- when: '"WSL" not in ansible_kernel'
|
||||
set_fact:
|
||||
SYSTEM_INFO_SCRIPT: '{{SYSTEM_INFO_SCRIPT_DIR}}/system-info-Linux.sh'
|
||||
- when: '"WSL" in ansible_kernel'
|
||||
set_fact:
|
||||
SYSTEM_INFO_SCRIPT: '{{SYSTEM_INFO_SCRIPT_DIR}}/system-info-WSL.sh'
|
||||
|
||||
- name: install system-info systemd unit
|
||||
template:
|
||||
src: templates/system-info.service.j2
|
||||
dest: ~/.config/systemd/user/system-info.service
|
||||
notify: restart system-info
|
||||
|
||||
- name: enable system-info service
|
||||
systemd:
|
||||
name: system-info
|
||||
scope: user
|
||||
enabled: true
|
||||
state: started
|
11
roles/system-info/tasks/RedHat.yaml
Normal file
11
roles/system-info/tasks/RedHat.yaml
Normal file
@ -0,0 +1,11 @@
|
||||
---
|
||||
- name: install dnf packages
|
||||
become: true
|
||||
dnf:
|
||||
name:
|
||||
- acpi
|
||||
- lm_sensors
|
||||
- sysstat
|
||||
state: latest
|
||||
|
||||
- include_tasks: Linux.yaml
|
6
roles/tidy/tasks/RedHat.yaml
Normal file
6
roles/tidy/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install dnf package
|
||||
become: true
|
||||
dnf:
|
||||
name: tidy
|
||||
state: latest
|
10
roles/tmux/tasks/RedHat.yaml
Normal file
10
roles/tmux/tasks/RedHat.yaml
Normal file
@ -0,0 +1,10 @@
|
||||
---
|
||||
- name: install yum packages
|
||||
become: true
|
||||
yum:
|
||||
name:
|
||||
- tmux
|
||||
- sysstat
|
||||
- urlview
|
||||
- xsel
|
||||
state: latest
|
6
roles/tree/tasks/RedHat.yaml
Normal file
6
roles/tree/tasks/RedHat.yaml
Normal file
@ -0,0 +1,6 @@
|
||||
---
|
||||
- name: install dnf package
|
||||
become: true
|
||||
dnf:
|
||||
name: tree
|
||||
state: latest
|
51
roles/yq/tasks/RedHat.yaml
Normal file
51
roles/yq/tasks/RedHat.yaml
Normal file
@ -0,0 +1,51 @@
|
||||
---
|
||||
- name: stat executable
|
||||
stat:
|
||||
path: '{{ansible_env.HOME}}/.local/bin/yq'
|
||||
register: yq_stat
|
||||
|
||||
- name: get installed version
|
||||
when: yq_stat.stat.exists
|
||||
command: yq --version
|
||||
changed_when: false
|
||||
register: yq_version
|
||||
|
||||
- name: extract installed version
|
||||
when: yq_stat.stat.exists
|
||||
set_fact:
|
||||
yq_installed_version:
|
||||
'{{yq_version.stdout.strip() | regex_replace("^.*(\d+\.\d+\.\d+).*$", "\1")}}'
|
||||
|
||||
- name: get latest release
|
||||
uri:
|
||||
url: 'https://api.github.com/repos/mikefarah/yq/releases/latest'
|
||||
register: latest
|
||||
|
||||
- name: determine if yq needs installed
|
||||
set_fact:
|
||||
yq_needs_installed:
|
||||
'{{not yq_stat.stat.exists or yq_installed_version != latest.json.tag_name}}'
|
||||
arch_dict: {x86_64: amd64, arm64: arm64}
|
||||
|
||||
- name: select asset name
|
||||
when: yq_needs_installed
|
||||
set_fact:
|
||||
asset_query:
|
||||
'[?contains(name, `yq_linux_{{arch_dict[ansible_architecture]}}`)] | [0]'
|
||||
- name: select asset
|
||||
when: yq_needs_installed
|
||||
set_fact:
|
||||
asset: '{{latest.json.assets | to_json | from_json | json_query(asset_query)}}'
|
||||
|
||||
- name: create directory
|
||||
when: yq_needs_installed
|
||||
file:
|
||||
path: '{{ansible_env.HOME}}/.local/bin'
|
||||
state: directory
|
||||
|
||||
- name: install executable
|
||||
when: yq_needs_installed
|
||||
get_url:
|
||||
url: '{{asset.browser_download_url}}'
|
||||
dest: '{{ansible_env.HOME}}/.local/bin/yq'
|
||||
mode: '0755'
|
8
roles/zsh/tasks/RedHat.yaml
Normal file
8
roles/zsh/tasks/RedHat.yaml
Normal file
@ -0,0 +1,8 @@
|
||||
---
|
||||
- name: install yum packages
|
||||
become: true
|
||||
yum:
|
||||
name:
|
||||
- zsh
|
||||
- pinentry-tty
|
||||
state: latest
|
Loading…
x
Reference in New Issue
Block a user