81 lines
2.5 KiB
YAML
81 lines
2.5 KiB
YAML
# Ansible Roles for managing Auengun.net Infrastructure & Testing/Learning.
|
|
# Source available at git.auengun.net/homelab/ansible-collection
|
|
# Copyright (C) 2023 GregoryDosh
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
# License, or (at your option) any later version.
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
# SPDX-FileCopyrightText: 2023 GregoryDosh
|
|
---
|
|
- name: Install sssd
|
|
become: true
|
|
ansible.builtin.package:
|
|
name: sssd
|
|
state: present
|
|
|
|
- name: create /etc/sssd/sssd.conf
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ role_path }}/templates/etc/sssd/sssd.conf"
|
|
dest: "/etc/sssd/sssd.conf"
|
|
owner: "root"
|
|
group: "root"
|
|
mode: "0600"
|
|
notify:
|
|
- "Restart sssd"
|
|
|
|
- name: create pam config for mkhomedir_spm
|
|
when: PAM_MKHOMEDIR_SPM_ENABLE | bool
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ role_path }}/templates/usr/share/pam-configs/auengun_mkhomedir"
|
|
dest: "/usr/share/pam-configs/auengun_mkhomedir"
|
|
owner: "root"
|
|
group: "root"
|
|
mode: "0644"
|
|
|
|
- name: enable auengun_mkhomedir pam module
|
|
when: PAM_MKHOMEDIR_SPM_ENABLE | bool
|
|
become: true
|
|
ansible.builtin.shell: |
|
|
pam-auth-update --enable auengun_mkhomedir
|
|
changed_when: false
|
|
|
|
- name: Add pam_ussh.so to security modules path
|
|
when: PAM_AUENGUN_SSH_ENABLE | bool
|
|
become: true
|
|
ansible.builtin.get_url:
|
|
url: "{{ PAM_SHARED_MODULE_URL }}"
|
|
dest: "{{ PAM_SHARED_MODULE_PATH }}/pam_ussh.so"
|
|
checksum: "sha256:{{ PAM_SHARED_MODULE_URL_SHA }}"
|
|
owner: "root"
|
|
group: "root"
|
|
mode: "0644"
|
|
|
|
- name: create pam config for auengun_ssh
|
|
when: PAM_AUENGUN_SSH_ENABLE | bool
|
|
become: true
|
|
ansible.builtin.template:
|
|
src: "{{ role_path }}/templates/usr/share/pam-configs/auengun_ssh"
|
|
dest: "/usr/share/pam-configs/auengun_ssh"
|
|
owner: "root"
|
|
group: "root"
|
|
mode: "0644"
|
|
|
|
- name: enable auengun_ssh pam module
|
|
when: PAM_AUENGUN_SSH_ENABLE | bool
|
|
become: true
|
|
ansible.builtin.shell: |
|
|
pam-auth-update --enable auengun_ssh
|
|
changed_when: false
|