44210a1fe8
The postfix service is currently being restarted whenever a config item changes. This is unnecessary as the postfix service can reload a new config. Set reload: True to prevent unnecessary restarts of the service. The old behavior can be restored by setting the pillar key reload_service to False.
116 lines
3.4 KiB
Plaintext
116 lines
3.4 KiB
Plaintext
{% from "postfix/map.jinja" import postfix with context %}
|
|
|
|
postfix:
|
|
pkg.installed:
|
|
- name: {{ postfix.package }}
|
|
{%- if grains['os_family']=="FreeBSD" %}
|
|
- force: True
|
|
- batch: True
|
|
{%- endif %}
|
|
- watch_in:
|
|
- service: postfix
|
|
service.running:
|
|
- enable: {{ salt['pillar.get']('postfix:enable_service', True) }}
|
|
- reload: {{ salt['pillar.get']('postfix:reload_service', True) }}
|
|
- require:
|
|
- pkg: postfix
|
|
- watch:
|
|
- pkg: postfix
|
|
|
|
{# Used for newaliases, postalias and postconf #}
|
|
{%- set default_database_type = salt['pillar.get']('postfix:config:default_database_type', 'hash') %}
|
|
|
|
# manage /etc/aliases if data found in pillar
|
|
{% if 'aliases' in pillar.get('postfix', '') %}
|
|
{% if salt['pillar.get']('postfix:aliases:use_file', true) == true %}
|
|
{%- set need_newaliases = False %}
|
|
{%- set file_path = postfix.aliases_file %}
|
|
{%- if ':' in file_path %}
|
|
{%- set file_type, file_path = postfix.aliases_file.split(':') %}
|
|
{%- else %}
|
|
{%- set file_type = default_database_type %}
|
|
{%- endif %}
|
|
{%- if file_type in ("btree", "cdb", "dbm", "hash", "sdbm") %}
|
|
{%- set need_newaliases = True %}
|
|
{%- endif %}
|
|
postfix_alias_database:
|
|
file.managed:
|
|
- name: {{ file_path }}
|
|
{% if salt['pillar.get']('postfix:aliases:content', None) is string %}
|
|
- contents_pillar: postfix:aliases:content
|
|
{% else %}
|
|
- source: salt://postfix/files/mapping.j2
|
|
{% endif %}
|
|
- user: root
|
|
- group: {{ postfix.root_grp }}
|
|
- mode: 644
|
|
- template: jinja
|
|
- context:
|
|
data: {{ salt['pillar.get']('postfix:aliases:present') }}
|
|
colon: True
|
|
- require:
|
|
- pkg: postfix
|
|
{%- if need_newaliases %}
|
|
cmd.wait:
|
|
- name: newaliases
|
|
- cwd: /
|
|
- watch:
|
|
- file: {{ file_path }}
|
|
{%- endif %}
|
|
{% else %}
|
|
{%- for user, target in salt['pillar.get']('postfix:aliases:present', {}).items() %}
|
|
postfix_alias_present_{{ user }}:
|
|
alias.present:
|
|
- name: {{ user }}
|
|
- target: {{ target }}
|
|
{%- endfor %}
|
|
{%- for user in salt['pillar.get']('postfix:aliases:absent', {}) %}
|
|
postfix_alias_absent_{{ user }}:
|
|
alias.absent:
|
|
- name: {{ user }}
|
|
{%- endfor %}
|
|
{% endif %}
|
|
{% endif %}
|
|
|
|
# manage various mappings
|
|
{% for mapping, data in salt['pillar.get']('postfix:mapping', {}).items() %}
|
|
{%- set need_postmap = False %}
|
|
{%- set file_path = salt['pillar.get']('postfix:config:' ~ mapping) %}
|
|
{%- if ':' in file_path %}
|
|
{%- set file_type, file_path = file_path.split(':') %}
|
|
{%- else %}
|
|
{%- set file_type = default_database_type %}
|
|
{%- endif %}
|
|
{%- if not file_path.startswith('/') %}
|
|
{%- set file_path = postfix.config_path ~ '/' ~ file_path %}
|
|
{%- endif %}
|
|
{%- if file_type in ("btree", "cdb", "dbm", "hash", "sdbm") %}
|
|
{%- set need_postmap = True %}
|
|
{%- endif %}
|
|
postfix_{{ mapping }}:
|
|
file.managed:
|
|
- name: {{ file_path }}
|
|
- source: salt://postfix/files/mapping.j2
|
|
- user: root
|
|
- group: {{ postfix.root_grp }}
|
|
{%- if mapping.endswith('_sasl_password_maps') %}
|
|
- mode: 600
|
|
{%- else %}
|
|
- mode: 644
|
|
{%- endif %}
|
|
- template: jinja
|
|
- context:
|
|
data: {{ data|json() }}
|
|
- require:
|
|
- pkg: postfix
|
|
{%- if need_postmap %}
|
|
cmd.wait:
|
|
- name: {{ postfix.xbin_prefix }}/sbin/postmap {{ file_path }}
|
|
- cwd: /
|
|
- watch:
|
|
- file: {{ file_path }}
|
|
- watch_in:
|
|
- service: postfix
|
|
{%- endif %}
|
|
{% endfor %}
|