Browse Source

feat(hourly): add configuration to enable hourly jobs

tags/v0.13.0
Michael Schmitt 3 years ago
parent
commit
7b5676b9e2
No account linked to committer's email address
5 changed files with 71 additions and 7 deletions
  1. +46
    -6
      logrotate/config.sls
  2. +4
    -0
      logrotate/defaults.yaml
  3. +8
    -1
      logrotate/jobs.sls
  4. +4
    -0
      logrotate/osfamilymap.yaml
  5. +9
    -0
      logrotate/templates/logrotate.hourly.tmpl

+ 46
- 6
logrotate/config.sls View File

include: include:
- logrotate - logrotate


{% set ns = namespace(hourly=False) %}
{% set jobs = salt['config.get']('logrotate:jobs', {}) %}
{% for key, value in logrotate.jobs.items() %}
{% set contents = value.get('contents', False) %}
{% if 'hourly' in (contents or value.config) %}
{% set ns.hourly = True %}
{% break %}
{% endif %}
{% endfor %}

logrotate-config: logrotate-config:
file.managed: file.managed:
- name: {{ logrotate.conf_file }} - name: {{ logrotate.conf_file }}
- source: salt://logrotate/templates/logrotate.conf.tmpl - source: salt://logrotate/templates/logrotate.conf.tmpl
- template: jinja - template: jinja
- user: {{ salt['pillar.get']('logrotate:config:user', logrotate.user) }}
- group: {{ salt['pillar.get']('logrotate:config:group', logrotate.group) }}
- mode: {{ salt['pillar.get']('logrotate:config:mode', '644') }}
- user: {{ salt['config.get']('logrotate:config:user', logrotate.user) }}
- group: {{ salt['config.get']('logrotate:config:group', logrotate.group) }}
- mode: {{ salt['config.get']('logrotate:config:mode', '0644') }}
- context: - context:
logrotate: {{ logrotate|tojson }} logrotate: {{ logrotate|tojson }}


logrotate-directory: logrotate-directory:
file.directory: file.directory:
- name: {{ logrotate.include_dir }} - name: {{ logrotate.include_dir }}
- user: {{ salt['pillar.get']('logrotate:config:user', logrotate.user) }}
- group: {{ salt['pillar.get']('logrotate:config:group', logrotate.group) }}
- mode: 755
- user: {{ salt['config.get']('logrotate:config:user', logrotate.user) }}
- group: {{ salt['config.get']('logrotate:config:group', logrotate.group) }}
- mode: '0755'
- makedirs: True

{%- if ns.hourly %}
logrotate-hourly-config:
file.managed:
- name: {{ logrotate.hourly_conf_file }}
- user: {{ salt['config.get']('logrotate:config:user', logrotate.user) }}
- group: {{ salt['config.get']('logrotate:config:group', logrotate.group) }}
- mode: {{ salt['config.get']('logrotate:config:mode', '0644') }}
- contents:
- include {{ logrotate.hourly_include_dir }}

logrotate-hourly-directory:
file.directory:
- name: {{ logrotate.hourly_include_dir }}
- user: {{ logrotate.user }}
- group: {{ logrotate.group }}
- mode: '0755'
- makedirs: True - makedirs: True


logrotate-hourly-cron:
file.managed:
- name: "/etc/cron.hourly/logrotate"
- source: salt://logrotate/templates/logrotate.hourly.tmpl
- template: jinja
- user: {{ salt['config.get']('logrotate:config:user', logrotate.user) }}
- group: {{ salt['config.get']('logrotate:config:group', logrotate.group) }}
- mode: '0775'
- context:
logrotate: {{ logrotate|tojson }}

{%- endif %}

+ 4
- 0
logrotate/defaults.yaml View File

# vim: ft=yaml # vim: ft=yaml
--- ---
logrotate: logrotate:
bin: /usr/sbin/logrotate
status_dir: /var/lib/logrotate
pkg: logrotate pkg: logrotate
conf_file: '/etc/logrotate.conf' conf_file: '/etc/logrotate.conf'
include_dir: '/etc/logrotate.d' include_dir: '/etc/logrotate.d'
hourly_conf_file: '/etc/logrotate.hourly.conf'
hourly_include_dir: '/etc/logrotate.hourly.d'
user: root user: root
group: root group: root
service: cron service: cron

+ 8
- 1
logrotate/jobs.sls View File



{% for key, value in jobs.items() %} {% for key, value in jobs.items() %}
{% set contents = value.get('contents', False) %} {% set contents = value.get('contents', False) %}

logrotate-{{ key }}: logrotate-{{ key }}:
file.managed: file.managed:
{% if 'hourly' in (contents or value.config) %}
- name: {{ logrotate.hourly_include_dir }}/{{ key.split("/")[-1] }}
- require:
- file: {{ logrotate.hourly_include_dir }}
{% else %}
- name: {{ logrotate.include_dir }}/{{ key.split("/")[-1] }} - name: {{ logrotate.include_dir }}/{{ key.split("/")[-1] }}
{% endif %}
- user: {{ salt['pillar.get']('logrotate:config:user', logrotate.user) }} - user: {{ salt['pillar.get']('logrotate:config:user', logrotate.user) }}
- group: {{ salt['pillar.get']('logrotate:config:group', logrotate.group) }} - group: {{ salt['pillar.get']('logrotate:config:group', logrotate.group) }}
- mode: {{ salt['pillar.get']('logrotate:config:mode', '644') }} - mode: {{ salt['pillar.get']('logrotate:config:mode', '644') }}
data: {{ value | json }} data: {{ value | json }}
{% endif %} {% endif %}
{% endif %} {% endif %}
{%- endfor -%}


{% endfor %}

+ 4
- 0
logrotate/osfamilymap.yaml View File

tabooext: + .keep tabooext: + .keep
dateext: true dateext: true
FreeBSD: FreeBSD:
bin: /usr/local/sbin/logrotate
status_dir: /var/run
conf_file: /usr/local/etc/logrotate.conf conf_file: /usr/local/etc/logrotate.conf
hourly_conf_file: /usr/local/etc/logrotate.hourly.conf
include_dir: /usr/local/etc/logrotate.d include_dir: /usr/local/etc/logrotate.d
hourly_include_dir: /usr/local/etc/logrotate.hourly.d
group: wheel group: wheel

+ 9
- 0
logrotate/templates/logrotate.hourly.tmpl View File

#!/bin/sh

{{ logrotate.bin }} -s {{ logrotate.status_dir }}/logrotate.hourly.status {{ logrotate.hourly_conf_file }}
EXITVALUE=$?
if [ $EXITVALUE != 0 ]; then
/usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]"
fi

exit 0

Loading…
Cancel
Save