postfix



This role can install, configure and start Postfix MTA.

Requirements

See below

Collection requirements

The role requires the firewall role and the selinux role from the fedora.linux_system_roles collection, if postfix_manage_firewall and postfix_manage_selinux is set to true, respectively. (Please see also postfix_manage_firewall and postfix_manage_selinux)

If the postfix is a role from the fedora.linux_system_roles collection or from the Fedora RPM package, the requirement is already satisfied.

The role requires additional collections to manage rpm-ostree systems. If you need to manage rpm-ostree systems, run the below command to install the collections.

ansible-galaxy collection install -r meta/collection-requirements.yml

Role Variables

postfix_conf

postfix_conf:
  relayhost: example.com

This is a dictionary which can hold key/value pairs of all supported Postfix configuration parameters. Keys not supported by the installed Postfix are ignored. The default is empty {}.

You can specify previous: replaced within the postfix_conf dictionary to remove any existing configuration and apply the desired configuration on top of clean postfix installation.

WARNING: If you specify previous: replaced, the role reinstalls the postfix package and replaces the existing /etc/postfix/main.cf and /etc/postfix/master.cf files. Ensure to back up those files to preserve your settings.

WARNING: When managing rpm-ostree systems, the role cannot reinstall the postfix package, so it just replaces the modified config files with empty files. This is not idempotent.

If you specify only previous: replaced under the postfix_conf dictionary, the role re-installs the postfix package and enables the postfix service without applying any configuration.

For example, to remove existing configuration and set relayhost: example.com on top of clean postfix installation, use postfix_conf like this:

postfix_conf:
  previous: replaced
  relayhost: example.com

postfix_files

postfix_files:
  - name: sasl_passwd
    content: example.com user:password
    postmap: true
  - name: sender_canonical_maps
    content: /.+/  info@example.com

This is a list of files that will be placed in /etc/postfix and that can be converted into Postfix Lookup Tables if needed.

It's meant as a simple mechanism to configure things such as SASL credentials and other small snippets.

postfix_check

postfix_check: false

This is a boolean which determines if postfix check is run before starting Postfix if the configuration has changed. The default is true.

postfix_backup

postfix_backup: true

This is a boolean which determines if the role will make a single backup copy of the configuration - for example, cp /etc/postfix/main.cf /etc/postfix/main.cf.backup, thus overwriting the previous backup, if any. The default is false. NOTE: If you want to set this to true, you must also set postfix_backup_multiple: false - see below.

postfix_backup_multiple

postfix_backup_multiple: false

This is a boolean which determines if the role will make a timestamped backup copy of the configuration - for example, cp /etc/postfix/main.cf /etc/postfix/main.cf.$(date -Isec), thus keeping multiple backup copies. The default is true. NOTE: This setting overrides postfix_backup, so you must set this to false if you want to use postfix_backup.

postfix_manage_firewall

Boolean flag allowing to configure firewall using the firewall role. Manage the smtp related ports, 25/tcp, 465/tcp, and 587/tcp. If the variable is set to false, the postfix role does not manage the firewall. Default to false.

NOTE: postfix_manage_firewall is limited to adding ports. It cannot be used for removing ports. If you want to remove ports, you will need to use the firewall system role directly.

NOTE: the firewall management is not supported on RHEL 6.

postfix_manage_selinux

Boolean flag allowing to configure selinux using the selinux role. Assign smtp_port_t to the smtp related ports. If the variable is set to false, the postfix role does not manage the selinux

NOTE: postfix_manage_selinux is limited to adding policy. It cannot be used for removing policy. If you want to remove policy, you will need to use the selinux system role directly.

Variables Exported by the Role

postfix_default_database_type

This is a string which specifies the default database type used by postfix, which is obtained by using postconf -h default_database_type. This can be used to set configuration which depends on the type. NOTE this is not supported with Ansible 2.9.

- name: Manage postfix
  hosts: all
  vars:
    postfix_conf:
      relay_domains: "{{ postfix_default_database_type }}:/etc/postfix/relay_domains"
  roles:
    - linux-system-roles.postfix

Limitations

There is no way to remove separate configuration parameters. As a workaround, you can use postfix_conf's previous: replaced to remove the existing configuration and then apply the desired configuration on top of clean postfix installation. For more information, see postfix_conf.

Example Playbook

Install and enable postfix. Configure relay_domains=$mydestination and relayhost=example.com.

---
- name: Manage postfix
  hosts: all
  vars:
    postfix_conf:
      relay_domains: $mydestination
      relayhost: example.com
  roles:
    - linux-system-roles.postfix

Install and enable postfix. Do not run 'postfix check' before restarting postfix:

---
- name: Manage postfix with no check
  hosts: all
  vars:
    postfix_check: false
  roles:
    - linux-system-roles.postfix

Install and enable postfix. Do single backup of main.cf (older backup will be rewritten) and configure relayhost=example.com:

---
- name: Manage postfix with relayhost
  hosts: all
  vars:
    postfix_conf:
      relayhost: example.com
    postfix_backup: true
  roles:
    - linux-system-roles.postfix

Install and enable postfix. Do timestamped backup of main.cf and configure relayhost=example.com (if postfix_backup_multiple is set to true postfix_backup is ignored):

---
- name: Manage postfix with multiple backups
  hosts: all
  vars:
    postfix_conf:
      relayhost: example.com
    postfix_backup_multiple: true
  roles:
    - linux-system-roles.postfix

rpm-ostree

See README-ostree.md

License

Copyright (C) 2017 Jaroslav Škarvada jskarvad@redhat.com

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.