/mail_relay

📨 A simplistic SMTP relay service for Gmail and Home Assistant

Primary LanguagePythonMIT LicenseMIT

Docker Python 3.9

Mail Relay

Background

While integrating the lawn mower to my existing home automation this embedded platform were only able to use plain SMTP for sending notification in comparison authenticating and trasmitting across TLS (rfc3207) that made it troublesome without a way for me "relaying" e-mail through another service. Now another advantage that came to my mind using this allows "all" my internal services (platforms) to be configured to be used one single "mail" service that allows me to reconfigure for any new mail destination without need doing this across all services.

I also extended this package also adding possibility to send notification to a Home Assistant environment e.g. allowing "push" messages to Apple IOS or Android devices.

Installation

From source

$ pip3 install git+https://github.com/engdan77/mail_relay.git

From Dockerhub

$ mkdir config
$ docker run -p 9587:9587 -p 9025:9025 -p 9080:9080 -v $(pwd)/config:/app/config -e CONFIG_PATH='/app/config' --name mail_relay engdan77/mail_relay

How to use

Just start it by mail_relay and you will get log messages to console

$ mail_relay

2021-11-16 19:58:07.426 | INFO     | mail_relay.__main__:main:185 - SMTP relay been started
2021-11-16 19:58:07.427 | INFO     | mail_relay.__main__:main:186 - listening to ports 9025(SMTP) 9587(TLS)
2021-11-16 19:58:07.428 | INFO     | mail_relay.__main__:main:187 - CTRL-C to exit
2021-11-16 20:05:07.484 | DEBUG    | mail_relay.__main__:handle_DATA:73 - Message from daniel@engvalls.eu
2021-11-16 20:05:07.485 | DEBUG    | mail_relay.__main__:handle_DATA:74 - Message for ['daniel@engvalls.eu']
2021-11-16 20:05:07.485 | DEBUG    | mail_relay.__main__:handle_DATA:75 - Message data:

2021-11-16 20:05:07.486 | DEBUG    | mail_relay.__main__:handle_DATA:84 - End of message
2021-11-16 20:05:07.486 | INFO     | mail_relay.__main__:sender:98 - email enabled
2021-11-16 20:05:07.487 | INFO     | mail_relay.__main__:notify_gmail:126 - body='fooo\n\n'
2021-11-16 20:05:07.487 | INFO     | mail_relay.__main__:notify_gmail:127 - sending gmail
2021-11-16 20:05:08.994 | INFO     | mail_relay.__main__:sender:101 - hass enabled
2021-11-16 20:05:08.995 | INFO     | mail_relay.__main__:sender:103 - sending to Home Assistant 10.1.1.5
2021-11-16 20:05:12.522 | DEBUG    | mail_relay.__main__:notify_hass:171 - hass response: <Response [200 OK]>

First run if no mail_relay.cfg been created a default one will be created that could be updated.

How to use

Just start it by mail_relay and you will get log messages to console

You are also able to send message using the REST api as example

curl -X POST 127.0.0.1:9080/send_message \
   -H 'Content-Type: application/json' \
   -d '{"subject":"My subject","message":"My message"}'

Or you can use the swagger docs to send using it http://127.0.0.1:9080/docs

Example configuration

This is a sample mail_relay.cfg where a default one being automatically generated within the config folder.

smtp_port: `$SMTP_PORT|9025`
tls_port: `$SMTP_PORT|9587`
api_port: `$API_PORT|9080`
gmail: {
    enabled: true,
    username: 'mygmailaccount',
    password: 'mypassword',
    to: 'myemail@foo.com'
}
hass: {
    enabled: true,
    host: `$HASS_HOST`,
    port: `$HASS_PORT`,
    target: `$HASS_TARGET`,
    key: `$HASS_KEY`
}

Now the $XXX|YYY means that if an environment variable XXX exists it will be used otherwise use YYY. More information can be read here.

Configure gmail service

All you need to supply is your gmail username, password and the email you like message to be forwarded to.

Configure "notification" service in Home Assistant

If you look closer how to add "notification" in HASS to be used as key in above configuration. And you also need to get access token (key) to be used with your integration, more information here.

A Home Assistant configuration.yaml where in such example I could use all_iphones set as target in above mail_relay configuration.

notify:
  - name: all_iphones
    platform: group
    services:
      - service: mobile_app_my_iphone
      - service: mobile_app_other_iphone

Tests and coverage

pytest --cov
================ test session starts =========================
platform darwin -- Python 3.9.5, pytest-6.2.5, py-1.10.0, pluggy-1.0.0
rootdir: /Users/edo/git/my/mail_relay
plugins: anyio-3.3.1, mock-3.6.1, cov-3.0.0, httpx-0.13.0
collected 4 items                                                                                                                                                          

tests/test_mail_relay.py ....                                                                                                                                        [100%]

---------- coverage: platform darwin, python 3.9.5-final-0 -----------
Name                     Stmts   Miss  Cover
--------------------------------------------
mail_relay/__init__.py       1      0   100%
mail_relay/__main__.py      91     21    77%
--------------------------------------------
TOTAL                       92     21    77%