-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
14 changed files
with
183 additions
and
176 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,15 +1,15 @@ | ||
--- | ||
auth__all: "{{ {'host': auth__host, 'group': auth__group, 'default': auth__default} | aybarsm.helper.role_items(only=auth__use_only) }}" | ||
|
||
auth__users_all: "{{ auth__all | selectattr('entry__type', 'eq', 'user') }}" | ||
auth__users_all: "{{ auth__all | selectattr('_type', 'eq', 'user') }}" | ||
|
||
auth__authorized_keys_all: "{{ auth__all | selectattr('entry__type', 'eq', 'authorized_key') }}" | ||
auth__authorized_keys_all: "{{ auth__all | selectattr('_type', 'eq', 'authorized_key') }}" | ||
|
||
auth__sshd_config_all: "{{ auth__all | selectattr('entry__type', 'eq', 'sshd_config') | | ||
auth__sshd_config_all: "{{ auth__all | selectattr('_type', 'eq', 'sshd_config') | | ||
sort(attribute='value', reverse=true) | sort(attribute='name', reverse=false) }}" | ||
|
||
auth__ssh_config_all: "{{ auth__all | selectattr('entry__type', 'eq', 'ssh_config') | | ||
auth__ssh_config_all: "{{ auth__all | selectattr('_type', 'eq', 'ssh_config') | | ||
sort(attribute='value', reverse=true) | sort(attribute='name', reverse=false) }}" | ||
|
||
__auth__key_distribute_query: "*.auth__users_apply.results[*] | [] | | ||
[?contains(not_null(item.entry__distribute_ssh_key,``),`{{ inventory_hostname }}`)].{user: name, key: ssh_public_key}" | ||
[?contains(not_null(item._distribute_ssh_key,``),`{{inventory_hostname }}`)].{user: name, key: ssh_public_key}" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,72 +1,67 @@ | ||
--- | ||
- name: Set Facts for Proxmox Freenas | ||
ansible.builtin.set_fact: | ||
freenas_remote_src: "{{ freenas_remote_src }}" | ||
freenas_delegate: "{{ inventory_hostname if freenas_remote_src else 'localhost' }}" | ||
vars: | ||
freenas_remote_src: "{{ __proxmox__purposes.freenas.remote_src | default(proxmox__purposes.freenas.remote_src) }}" | ||
register: proxmox__freenas__set_fact | ||
- name: Apply Freenas | ||
block: | ||
- name: Create Temp Directory for Git Repo | ||
ansible.builtin.tempfile: | ||
state: directory | ||
register: proxmox__freenas__temp_dir | ||
delegate_to: "{{ inventory_hostname if __proxmox__purposes.freenas.remote_src else 'localhost' }}" | ||
|
||
- name: Create Temp Directory for Git Repo | ||
ansible.builtin.tempfile: | ||
state: directory | ||
register: proxmox__freenas__temp_dir | ||
delegate_to: "{{ freenas_delegate }}" | ||
- name: Include Git Task to Clone Freenas Repo | ||
ansible.builtin.include_role: | ||
name: aybarsm.helper.misc | ||
tasks_from: ansible/builtin/git.yml | ||
vars: | ||
misc__item: | ||
repo: https://github.com/TheGrandWazoo/freenas-proxmox | ||
clone: true | ||
dest: "{{ proxmox__freenas__temp_dir.path }}" | ||
_module: | ||
delegate_to: "{{ inventory_hostname if __proxmox__purposes.freenas.remote_src else 'localhost' }}" | ||
register: proxmox__freenas__git | ||
when: proxmox__freenas__temp_dir.path is defined | ||
|
||
- name: Include Git Task to Clone Freenas Repo | ||
ansible.builtin.include_role: | ||
name: aybarsm.helper.misc | ||
tasks_from: ansible/builtin/git.yml | ||
vars: | ||
misc__item: | ||
repo: https://github.com/TheGrandWazoo/freenas-proxmox | ||
clone: true | ||
dest: "{{ proxmox__freenas__temp_dir.path }}" | ||
__module: | ||
delegate_to: "{{ freenas_delegate }}" | ||
register: proxmox__freenas__git | ||
when: proxmox__freenas__temp_dir.path is defined | ||
|
||
- name: Include File Manager Role to Apply Changes | ||
ansible.builtin.include_role: | ||
name: aybarsm.helper.file_mgr | ||
vars: | ||
file_mgr__role_enabled: true | ||
file_mgr__strict_safe: true | ||
file_mgr__no_log: false | ||
file_mgr__use_only: ['host'] | ||
file_mgr__host: | ||
- entry__type: patch | ||
src: "{{ proxmox__freenas__temp_dir.path }}/pve-manager/js/pvemanagerlib.js.patch" | ||
dest: /usr/share/pve-manager/js/pvemanagerlib.js | ||
remote_src: "{{ freenas_remote_src }}" | ||
entry__handlers: restart_pve_services | ||
- entry__type: patch | ||
src: "{{ proxmox__freenas__temp_dir.path }}/perl5/PVE/Storage/ZFSPlugin.pm.patch" | ||
dest: /usr/share/perl5/PVE/Storage/ZFSPlugin.pm | ||
remote_src: "{{ freenas_remote_src }}" | ||
entry__handlers: restart_pve_services | ||
- entry__type: patch | ||
src: "{{ proxmox__freenas__temp_dir.path }}/pve-docs/api-viewer/apidoc.js.patch" | ||
dest: /usr/share/pve-docs/api-viewer/apidoc.js | ||
remote_src: "{{ freenas_remote_src }}" | ||
entry__handlers: restart_pve_services | ||
- entry__type: copy | ||
src: "{{ proxmox__freenas__temp_dir.path }}/perl5/PVE/Storage/LunCmd/FreeNAS.pm" | ||
dest: /usr/share/perl5/PVE/Storage/LunCmd/FreeNAS.pm | ||
remote_src: "{{ freenas_remote_src }}" | ||
entry__handlers: restart_pve_services | ||
- entry__type: handlers | ||
name: restart_pve_services | ||
condition: any | ||
handlers: "{{ {'name': ['pvedaemon', 'pveproxy', 'pvestatd', 'pve-ha-lrm', 'pve-ha-crm']} | | ||
aybarsm.helper.to_list_of_dicts({'entry__type': 'service', 'state': 'restarted'}) }}" | ||
register: proxmox__freenas__patch | ||
when: proxmox__freenas__temp_dir.path is defined | ||
|
||
- name: Remove Git Repo Temp Directory | ||
ansible.builtin.file: | ||
path: "{{ proxmox__freenas__temp_dir.path }}" | ||
state: absent | ||
delegate_to: "{{ freenas_delegate }}" | ||
when: proxmox__freenas__temp_dir.path is defined | ||
- name: Include File Manager Role to Apply Changes | ||
ansible.builtin.include_role: | ||
name: aybarsm.helper.file_mgr | ||
vars: | ||
file_mgr__role_enabled: true | ||
file_mgr__strict_safe: true | ||
file_mgr__no_log: false | ||
file_mgr__use_only: ['host'] | ||
file_mgr__host: | ||
- _type: patch | ||
src: "{{ proxmox__freenas__temp_dir.path }}/pve-manager/js/pvemanagerlib.js.patch" | ||
dest: /usr/share/pve-manager/js/pvemanagerlib.js | ||
remote_src: "{{ __proxmox__purposes.freenas.remote_src }}" | ||
_handler: restart_pve_services | ||
- _type: patch | ||
src: "{{ proxmox__freenas__temp_dir.path }}/perl5/PVE/Storage/ZFSPlugin.pm.patch" | ||
dest: /usr/share/perl5/PVE/Storage/ZFSPlugin.pm | ||
remote_src: "{{ __proxmox__purposes.freenas.remote_src }}" | ||
_handler: restart_pve_services | ||
- _type: patch | ||
src: "{{ proxmox__freenas__temp_dir.path }}/pve-docs/api-viewer/apidoc.js.patch" | ||
dest: /usr/share/pve-docs/api-viewer/apidoc.js | ||
remote_src: "{{ __proxmox__purposes.freenas.remote_src }}" | ||
_handler: restart_pve_services | ||
- _type: copy | ||
src: "{{ proxmox__freenas__temp_dir.path }}/perl5/PVE/Storage/LunCmd/FreeNAS.pm" | ||
dest: /usr/share/perl5/PVE/Storage/LunCmd/FreeNAS.pm | ||
remote_src: "{{ __proxmox__purposes.freenas.remote_src }}" | ||
_handler: restart_pve_services | ||
- _type: handler | ||
_name: restart_pve_services | ||
_when: any | ||
_actions: "{{ {'name': ['pvedaemon', 'pveproxy', 'pvestatd', 'pve-ha-lrm', 'pve-ha-crm']} | | ||
aybarsm.helper.to_list_of_dicts({'_type': 'service', 'state': 'restarted'}) }}" | ||
register: proxmox__freenas__patch | ||
when: proxmox__freenas__temp_dir.path is defined | ||
|
||
always: | ||
- name: Remove Git Repo Temp Directory | ||
ansible.builtin.file: | ||
path: "{{ proxmox__freenas__temp_dir.path }}" | ||
state: absent | ||
delegate_to: "{{ inventory_hostname if __proxmox__purposes.freenas.remote_src else 'localhost' }}" | ||
when: proxmox__freenas__temp_dir.path is defined |
Oops, something went wrong.