Find a file
2022-07-31 11:15:55 +02:00
defaults BUMP msmtp-1.8.20-1 2022-05-12 21:58:49 +02:00
files Remove msmtp-1.8.19-1 files 2022-07-31 11:15:55 +02:00
handlers fix handler 2021-07-12 21:51:38 +02:00
meta Molecule fix 2022-02-20 13:49:00 +01:00
molecule/default yamllint 2021-07-12 21:39:30 +02:00
tasks Send test email on rpm upgrade 2022-02-04 23:26:57 +01:00
templates Convert to RHEL support 2021-05-15 17:20:39 +02:00
tests Enable test mail by default; disable on travis 2018-05-08 20:18:28 +08:00
vars yamllint + ansible-lint 2021-07-01 20:52:55 +02:00
.ansible-lint Fix molecule - hopefully 2022-02-20 13:30:06 +01:00
.gitignore use gitignore_global instead 2019-08-05 15:36:18 +08:00
docker_rpmbuild-rebuild_msmtp.sh Bump to F36 build (no changes) 2022-07-31 11:14:07 +02:00
LICENSE Update meta and readme 2018-05-07 22:28:10 +08:00
README.md Update Readme.MD 2021-05-15 17:31:16 +02:00

Build Status

ansible-msmtp-mailer

This ansible role deploys msmtp as a mailer for RHEL8 and compatible.

Prerequisite

  • Access to a functioning SMTP server.

How to install

  • Either use framagit to clone/download into your roles directory:
    • git clone https://framagit.org/garbaye/ansible-msmtp-mailer.git
  • Or import in your requirements.yml:
    roles:
      - src: git+https://framagit.org/garbaye/ansible-msmtp-mailer.git
    

Variables

All the default variables are located defaults/main.yml. Mostly you would need to configure the following variables.

  • msmtp_accounts: You can define one or more smtp accounts:

    msmtp_accounts:
    - account:   gmail
      host:      smtp.gmail.com
      port:      587
      auth:      "on"
      from:      example@gmail.example
      user:      example@gmail.example
      password:  "some password"
    - account:   mysmtp
      host:      smtp.example
      port:      587
      auth:      "on"
      from:      admin@example.org
      user:      myuser@example.org
      password:  plain-text-password2
    
  • msmtp_default_account: Default smtp account to use

    msmtp_default_account: "gmail"

  • Logging

    • Option A (syslog)

       msmtp_log : "syslog"
      
    • Option B (file logging)

       msmtp_log     : "file"
       msmtp_logfile : /var/log/msmtp.log
      
    • Option C (No logging)

       msmtp_log     : "no"
      
  • Mail aliases

    • msmtp_alias_default: default email this required

      msmtp_alias_default : ops@example.com

    • msmtp_alias_root: root email this is optional

      msmtp_alias_root : root@example.com

    • msmtp_alias_cron: cron email this optional

      msmtp_alias_cron : cron@example.com

Configure

You can configure your variables in ansible with one of the following

  • Create a variable in host/group variables directory.
  • Editing vars/main.yml
  • Run ansible-playbook with -e
  • Edit the defaults/main.yml (not recommended)

Example Playbook

---
- hosts: all
  roles:
    - ansible-msmtp-mailer

Run

  • mstmp used to function out of the box with the provided defaults/main.yml settings, because the configuration used a real smtp server for testing, but Yandex does not allow this any more. Instead use a Gmail account for testing.

    ansible-playbook -l hostname msmtp.yml

Test

You should get a test mail if it works as expected on the root mail

Documentation

msmtp manual

Authors:

License:

  • Apache 2.0