From b13d0940e39f759a4668657ebb7416f28022f9e5 Mon Sep 17 00:00:00 2001 From: Tomas Barton Date: Sat, 24 Aug 2024 21:10:20 +0200 Subject: [PATCH] Manage cron subdirectories, if needed --- manifests/cron.pp | 18 ++++++++++++++++++ manifests/init.pp | 1 + spec/classes/init_spec.rb | 22 ++++++++++++++++++++++ 3 files changed, 41 insertions(+) diff --git a/manifests/cron.pp b/manifests/cron.pp index 4dcb5b05..105e7b10 100644 --- a/manifests/cron.pp +++ b/manifests/cron.pp @@ -46,6 +46,24 @@ } } + if $logrotate::manage_cron_subdirectories { + case $facts['os']['family'] { + 'FreeBSD': {} + default: { + $cron_dir = "/etc/cron.${name}" + ensure_resources('file', { $cron_dir => { + ensure => directory, + owner => $logrotate::root_user, + group => $logrotate::root_group, + } }) + + File <<| name == $script_path |>> { + require => File[$cron_dir] + } + } + } + } + file { $script_path: ensure => $ensure, owner => $logrotate::root_user, diff --git a/manifests/init.pp b/manifests/init.pp index 47381b71..aaea75c0 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -28,6 +28,7 @@ String $root_group = $logrotate::params::root_group, Array[String[1]] $logrotate_args = [], Boolean $cron_always_output = false, + Boolean $manage_cron_subdirectories = true, ) inherits logrotate::params { contain logrotate::install contain logrotate::config diff --git a/spec/classes/init_spec.rb b/spec/classes/init_spec.rb index 2b649bec..ef706e78 100644 --- a/spec/classes/init_spec.rb +++ b/spec/classes/init_spec.rb @@ -203,6 +203,28 @@ it { is_expected.to contain_file('/etc/cron.hourly/logrotate').with_ensure('absent') } end end + + context 'with logrotate rule' do + let(:params) {{ + manage_cron_hourly: true, + rules: { + nginx: { + path: ['/var/log/nginx/*.log'], + rotate_every: 'hour', + } + } + }} + + case os_facts['os']['name'] + when 'FreeBSD' + it { is_expected.to contain_file('/usr/local/etc/logrotate.d/hourly').with_ensure('directory') } + else + it { is_expected.to contain_file('/etc/logrotate.d/hourly').with_ensure('directory') } + it { is_expected.to contain_file('/etc/logrotate.d/hourly/nginx').with_ensure('present').with_content(%r{/var/log/nginx/\*.log\s\{\n\s+hourly\n\}}) } + it { is_expected.to contain_file('/etc/cron.hourly').with_ensure('directory') } + it { is_expected.to contain_logrotate__rule('nginx') } + end + end end end end