{%- from "logrotate/map.jinja" import logrotate with context -%}
{%- set config = salt['pillar.get']('logrotate:default_config', logrotate.default_config) -%}

{%- set processed_parameters = [] -%}

{%- macro set_parameter(parameter, default=None) -%}
{%- set value = config.get(parameter, default) -%}
{%- if value is not none %}
  {%- if value is sameas true -%}
{{ parameter }}
  {%- elif value is sameas false -%}
no{{ parameter }}
  {%- elif value is string or value is number -%}
{{ parameter }} {{ value }}
  {%- else -%}
{{ value }}
  {%- endif %}
{%- do processed_parameters.append(parameter) %}
{%- endif %}
{%- endmacro -%}

# Managed by saltstack
#
# See "man logrotate" for details.

# log files rotation period
{% for period in ['hourly', 'daily', 'weekly', 'yearly'] -%}
{{ set_parameter(period) }}
{%- endfor %}

# keep x periods worth of backlogs
{{ set_parameter('rotate', 4) }}

# create new (empty) log files after rotating old ones
{{ set_parameter('create', True) }}

# use date as a suffix of the rotated file
{{ set_parameter('dateext', False) }}

# change this if you want your log files compressed
{{ set_parameter('compress', False) }}

{#- Accept arbitrary parameters #}
{%- for parameter in config %}
  {%- if parameter not in processed_parameters %}
{{ set_parameter(parameter) }}
  {%- endif %}
{%- endfor %}

# packages drop log rotation information into this directory
include {{ logrotate.include_dir }}

{% if logrotate.login_records_jobs -%}
# no packages own wtmp and btmp -- we'll rotate them here
/var/log/wtmp {
    monthly
    create 0664 root utmp
    minsize 1M
    rotate 1
}

/var/log/btmp {
    missingok
    monthly
    create 0600 root utmp
    rotate 1
}
{%- endif %}

# system-specific logs may be configured here