Create a linux package_manager role.
This commit is contained in:
14
ansible/roles/package_manager/tasks/common.yaml
Normal file
14
ansible/roles/package_manager/tasks/common.yaml
Normal file
@@ -0,0 +1,14 @@
|
||||
- import_tasks: tasks/freebsd.yaml
|
||||
when: 'os_flavor == "freebsd"'
|
||||
|
||||
- import_tasks: tasks/linux.yaml
|
||||
when: 'os_flavor == "linux"'
|
||||
|
||||
- include_tasks:
|
||||
file: tasks/peruser.yaml
|
||||
apply:
|
||||
become: yes
|
||||
become_user: "{{ initialize_user }}"
|
||||
loop: "{{ users | dict2items | community.general.json_query('[?value.initialize==`true`].key') }}"
|
||||
loop_control:
|
||||
loop_var: initialize_user
|
||||
5
ansible/roles/package_manager/tasks/freebsd.yaml
Normal file
5
ansible/roles/package_manager/tasks/freebsd.yaml
Normal file
@@ -0,0 +1,5 @@
|
||||
# - name: Install packages
|
||||
# package:
|
||||
# name:
|
||||
# - foo
|
||||
# state: present
|
||||
54
ansible/roles/package_manager/tasks/linux.yaml
Normal file
54
ansible/roles/package_manager/tasks/linux.yaml
Normal file
@@ -0,0 +1,54 @@
|
||||
- name: Put in custom config directory
|
||||
copy:
|
||||
src: "files/{{ pacman_conf }}/pacman.conf"
|
||||
dest: /etc/pacman.conf
|
||||
mode: 0644
|
||||
owner: root
|
||||
group: root
|
||||
|
||||
- name: Put in mirrolist
|
||||
copy:
|
||||
src: "files/{{ pacman_conf }}/mirrorlist"
|
||||
dest: /etc/pacman.d/mirrorlist
|
||||
mode: 0644
|
||||
owner: root
|
||||
group: root
|
||||
|
||||
- name: Create pacman conf directory
|
||||
file:
|
||||
name: /etc/pacman.d/conf.d
|
||||
state: directory
|
||||
owner: root
|
||||
group: root
|
||||
mode: 0755
|
||||
|
||||
- name: Check that paths exist
|
||||
stat:
|
||||
path: "{{ item }}"
|
||||
register: file_exists
|
||||
no_log: True
|
||||
loop:
|
||||
- /etc/pacman.d/conf.d/blank.conf
|
||||
|
||||
- name: Create blank file to match glob
|
||||
file:
|
||||
name: "{{ item }}"
|
||||
state: touch
|
||||
owner: root
|
||||
group: root
|
||||
mode: 0644
|
||||
loop:
|
||||
- /etc/pacman.d/conf.d/blank.conf
|
||||
when: "{{ file_exists | community.general.json_query(sub_query) | first | default(False) }} == False"
|
||||
vars:
|
||||
sub_query: "results[?stat.path=='{{ item }}'].stat.exists"
|
||||
|
||||
- name: Additional pacman configs
|
||||
copy:
|
||||
src: "files/{{ item }}"
|
||||
dest: /etc/pacman.d/conf.d/
|
||||
mode: 0644
|
||||
owner: root
|
||||
group: root
|
||||
loop:
|
||||
- freeze_firefox.conf
|
||||
1
ansible/roles/package_manager/tasks/main.yaml
Normal file
1
ansible/roles/package_manager/tasks/main.yaml
Normal file
@@ -0,0 +1 @@
|
||||
- import_tasks: tasks/common.yaml
|
||||
29
ansible/roles/package_manager/tasks/peruser.yaml
Normal file
29
ansible/roles/package_manager/tasks/peruser.yaml
Normal file
@@ -0,0 +1,29 @@
|
||||
- include_role:
|
||||
name: per_user
|
||||
|
||||
# - name: Create directories
|
||||
# file:
|
||||
# name: "{{ account_homedir.stdout }}/{{ item }}"
|
||||
# state: directory
|
||||
# mode: 0700
|
||||
# owner: "{{ account_name.stdout }}"
|
||||
# group: "{{ group_name.stdout }}"
|
||||
# loop:
|
||||
# - ".config/foo"
|
||||
|
||||
# - name: Copy files
|
||||
# copy:
|
||||
# src: "files/{{ item.src }}"
|
||||
# dest: "{{ account_homedir.stdout }}/{{ item.dest }}"
|
||||
# mode: 0600
|
||||
# owner: "{{ account_name.stdout }}"
|
||||
# group: "{{ group_name.stdout }}"
|
||||
# loop:
|
||||
# - src: foo.conf
|
||||
# dest: .config/foo/foo.conf
|
||||
|
||||
- import_tasks: tasks/peruser_freebsd.yaml
|
||||
when: 'os_flavor == "freebsd"'
|
||||
|
||||
- import_tasks: tasks/peruser_linux.yaml
|
||||
when: 'os_flavor == "linux"'
|
||||
Reference in New Issue
Block a user