sshd_config: checks for include-option, provided => write to 99-default.conf, else to sshd_config and prepend include to sshd_config, if not found.

master
Denis Knauf 2024-01-14 22:32:35 +01:00
parent 857897eb39
commit f7c525f38c
1 changed files with 29 additions and 9 deletions

View File

@ -1,15 +1,35 @@
---
# vim: set expandtab tabstop=2 shiftwidth=2:
- when: '"debian" == ansible_facts["distribution"]|lower and 12 <= ansible_facts["distribution_version"]|int'
name: 'sshd_config.d/99-default.conf'
template:
src: 'sshd-default.conf.j2'
dest: '/etc/ssh/sshd_config.d/99-default.conf'
owner: root
group: root
mode: 0644
- when: '"debian" != ansible_facts["distribution"]|lower or 11 >= ansible_facts["distribution_version"]|int'
- name: 'check sshd include option'
command: 'sshd -o "include /dev/null"'
register: sshd_include_option_check
failed_when: 'sshd_include_option_check.rc not in [1,255] or sshd_include_option_check.stderr not in ["Include directive not supported as a command-line option", "command-line: line 0: Bad configuration option: include"]'
- set_facts:
sshd_include_option: 'sshd_include_option_check.stderr == "Include directive not supported as a command-line option"'
- when: 'true == sshd_include_option'
block:
- name: '/etc/ssh/sshd_config.d'
file:
type: directory
dest: '/etc/ssh/sshd_config.d'
owner: root
group: root
mode: 0644
- name: 'sshd_config.d/99-default.conf'
template:
src: 'sshd-default.conf.j2'
dest: '/etc/ssh/sshd_config.d/99-default.conf'
owner: root
group: root
mode: 0644
- lineinfile:
path: /etc/ssh/sshd_config
insertbefore: BOF
regexp: '^\s*include\s+/etc/ssh/sshd_config.d/'
line: 'include /etc/ssh/sshd_config.d/*.conf'
firstmatch: true
- when: 'false == sshd_include_option'
block:
- name: sshd_config
lineinfile: