f451 Communications Module
Project description
TL;DR
This module provides a universal interface for various communications systems and services (e.g. email, Slack, SMS, etc.) and makes it possible to send the same message to several services with a single method call. The same call structure is used regardless of which services are enabled.
Installation
WARNING: This module is in early alpha stage. And while the code works (and passes all the tests), use at your own risk 🤓
You can install the f451 Communications module via pip from PyPi:
$ pip install f451-comms
Please see the section “Installation” in the main documentation for more information.
Quickstart
A common use case for the f451 Communications module is in applications that send (usually programmatically generated) messages via one or more channels. The module assumes that you provide all necessary keys and secrets required to verify your credentials with the services linked to the channels that you want to use.
It is recommended that you store these keys and secrets in a separate file (e.g. secrets.ini). However, it is also possible to submit them – for example during testing – in the form of a so-called dict structure.
from configparser import ConfigParser, ExtendedInterpolation
from f451_comms.comms import Comms
secrets = ConfigParser(interpolation=ExtendedInterpolation())
secrets.read("_PATH_TO_YOUR_SECRETS_FILE_")
comms = Comms(secrets)
comms.send_message("Hello world!", "all")
The basic sequence is to first initialize the Comms object with the keys and secrets required to authenticate with the services that you want to use. After that you can send messages to one or more channels with a single method call to the Comms object.
The send_message() method also has a 3rd argument that allows you to include additional attributes using a dict structure. These attributes can contain a wide variety of items. For example, you can include the HTML version of an email, or Slack blocks for more complex Slack messages. You can also include references to images to be included with the message, or files to be attached to emails, and so on.
Please see the section “Getting started” in the main documentation for more information.
Run a demo of this module
This module comes with a demo that allows you to experiment with sending messages to the various channels. Of course, you must first ensure that you have accounts with the services that you want to experiment with. You must also provide the appropriate credentials when starting the demo or it will simply fail to authenticate with the services you’re trying to use.
Please see the section “Run demo” in the main documentation for more information.
Background
This module was originally created to “scratch an itch” – or, as we say in marketing parlance: to solve a particular use case. 😉 – I had several single-purpose applications running on different devices (e.g. Raspberry Pi) configured to support specific hardware configurations (i.e. sensors and displays, etc.), services, or functions. And all applications were designed to notify me via different channels that certain events had occurred and so on.
Using a standardized communications library made it easy to have the main application on each device communicate results to the same channels without writing duplicate code for each application for a given device. Instead, I can now import this library, and most/all per-application customization can be handled by updating config files on each device.
For example, I have several devices that continuously collect data from sensors and perform various processing tasks on that data. Then, at regular intervals, when specific tasks are completed or certain events are triggered, I get notified via SMS, some fancy Slack message, or even get a nice HTML-based email with a status update, etc. And in some cases, the devices also notify the world via Twitter that whatever status was updated.
But most importantly, I’m able to call a simple send_message() method, which works the same way regardless of which services are enabled for a given device. And if I add a new communications channel, I can enable it quickly on my devices without updating the core applications. Simply adding the new channel to a configuration file is enough 😎
Current support:
Email via Mailgun – plain text and HTML, with attachments and inline images
Slack – plain text and Slack blocks
SMS via Twilio – SMS with images
Twitter – status updates and DMs
Future support:
Other - I know, this is really specific … but there will be more 😜
Documentation
Please refer to the documentation for more information.
Contributing
Contributions are very welcome. To learn more, see the Contributor Guide.
License
Distributed under the terms of the MIT license, the f451 Communications module is free and open source software.
Issues
If you encounter any problems, please file an issue along with a detailed description.
Credits
This project was generated from @cjolowicz’s Hypermodern Python Cookiecutter template.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file f451-comms-0.1.1.tar.gz
.
File metadata
- Download URL: f451-comms-0.1.1.tar.gz
- Upload date:
- Size: 37.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6181dd0d256bcb8b6f9b855a8b09c1844737b71bc7d1fe3d35480e595f7d77ff |
|
MD5 | f2eb3c22cfea9ce3cef382786ed578f4 |
|
BLAKE2b-256 | bd549ede914724c5ee7e9f7e3fcc07825328fecc55dc02bcfd45e785703b1f36 |
File details
Details for the file f451_comms-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: f451_comms-0.1.1-py3-none-any.whl
- Upload date:
- Size: 45.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d456fa933e70d2a020b2ec589bb3438f9f2e2e708315ad1ec9935566bcbf776c |
|
MD5 | 94f9672d777c14e6a91d5e2f1b0fe2d7 |
|
BLAKE2b-256 | 6007612f9ad411a96c1d9e3fd8912af8ac060ecaf0b04c6ae17184b23891e7a3 |