34a112faab
* Similar situation to https://github.com/saltstack-formulas/logrotate-formula/pull/53 - https://freenode.logbot.info/saltstack-formulas/20200507#c3819526-c3819581 - https://freenode.logbot.info/saltstack-formulas/20200508#c3826763-c3826995 * Send template values by `context`
125 lines
3.0 KiB
Plaintext
125 lines
3.0 KiB
Plaintext
{% from "postfix/map.jinja" import postfix with context %}
|
|
include:
|
|
- postfix
|
|
|
|
{{ postfix.config_path }}:
|
|
file.directory:
|
|
- user: root
|
|
- group: {{ postfix.root_grp }}
|
|
- dir_mode: 755
|
|
- file_mode: 644
|
|
- makedirs: True
|
|
|
|
{{ postfix.config_path }}/main.cf:
|
|
file.managed:
|
|
- source: salt://postfix/files/main.cf
|
|
- user: root
|
|
- group: {{ postfix.root_grp }}
|
|
- mode: 644
|
|
- require:
|
|
- pkg: postfix
|
|
- watch_in:
|
|
- service: postfix
|
|
- template: jinja
|
|
- context:
|
|
postfix: {{ postfix|tojson }}
|
|
|
|
{% if 'vmail' in pillar.get('postfix', '') %}
|
|
{{ postfix.config_path }}/virtual_alias_maps.cf:
|
|
file.managed:
|
|
- source: salt://postfix/files/virtual_alias_maps.cf
|
|
- user: root
|
|
- group: postfix
|
|
- mode: 640
|
|
- require:
|
|
- pkg: postfix
|
|
- watch_in:
|
|
- service: postfix
|
|
- template: jinja
|
|
|
|
{{ postfix.config_path }}/virtual_mailbox_domains.cf:
|
|
file.managed:
|
|
- source: salt://postfix/files/virtual_mailbox_domains.cf
|
|
- user: root
|
|
- group: postfix
|
|
- mode: 640
|
|
- require:
|
|
- pkg: postfix
|
|
- watch_in:
|
|
- service: postfix
|
|
- template: jinja
|
|
|
|
{{ postfix.config_path }}/virtual_mailbox_maps.cf:
|
|
file.managed:
|
|
- source: salt://postfix/files/virtual_mailbox_maps.cf
|
|
- user: root
|
|
- group: postfix
|
|
- mode: 640
|
|
- require:
|
|
- pkg: postfix
|
|
- watch_in:
|
|
- service: postfix
|
|
- template: jinja
|
|
{% endif %}
|
|
|
|
{% if salt['pillar.get']('postfix:manage_master_config', True) %}
|
|
{% import_yaml "postfix/services.yaml" as postfix_master_services %}
|
|
{{ postfix.config_path }}/master.cf:
|
|
file.managed:
|
|
- source: salt://postfix/files/master.cf
|
|
- user: root
|
|
- group: {{ postfix.root_grp }}
|
|
- mode: 644
|
|
- require:
|
|
- pkg: postfix
|
|
- watch_in:
|
|
- service: postfix
|
|
- template: jinja
|
|
- context:
|
|
postfix: {{ postfix|tojson }}
|
|
postfix_master_services: {{ postfix_master_services|tojson }}
|
|
{% endif %}
|
|
|
|
{% if 'transport' in pillar.get('postfix', '') %}
|
|
{{ postfix.config_path }}/transport:
|
|
file.managed:
|
|
- source: salt://postfix/files/transport
|
|
- user: root
|
|
- group: {{ postfix.root_grp }}
|
|
- mode: 644
|
|
- require:
|
|
- pkg: postfix
|
|
- watch_in:
|
|
- service: postfix
|
|
- template: jinja
|
|
|
|
run-postmap:
|
|
cmd.wait:
|
|
- name: {{ postfix.xbin_prefix }}/sbin/postmap {{ postfix.config_path }}/transport
|
|
- cwd: /
|
|
- watch:
|
|
- file: {{ postfix.config_path }}/transport
|
|
{% endif %}
|
|
|
|
{%- for domain in salt['pillar.get']('postfix:certificates', {}).keys() %}
|
|
|
|
postfix_{{ domain }}_ssl_certificate:
|
|
|
|
file.managed:
|
|
- name: {{ postfix.config_path }}/ssl/{{ domain }}.crt
|
|
- makedirs: True
|
|
- contents_pillar: postfix:certificates:{{ domain }}:public_cert
|
|
- watch_in:
|
|
- service: postfix
|
|
|
|
postfix_{{ domain }}_ssl_key:
|
|
file.managed:
|
|
- name: {{ postfix.config_path }}/ssl/{{ domain }}.key
|
|
- mode: 600
|
|
- makedirs: True
|
|
- contents_pillar: postfix:certificates:{{ domain }}:private_key
|
|
- watch_in:
|
|
- service: postfix
|
|
|
|
{% endfor %}
|