Skip to main content

mqttwarn - subscribe to MQTT topics and notify pluggable services

Project description

https://cloud.githubusercontent.com/assets/2345521/6320105/4dd7a826-bade-11e4-9a61-72aa163a40a9.png

To warn, alert, or notify.

https://raw.githubusercontent.com/mqtt-tools/mqttwarn/main/assets/google-definition.jpg

Status

https://github.com/mqtt-tools/mqttwarn/workflows/Tests/badge.svg https://codecov.io/gh/mqtt-tools/mqttwarn/branch/main/graph/badge.svg https://img.shields.io/pypi/pyversions/mqttwarn.svg

https://img.shields.io/pypi/l/mqttwarn.svg https://img.shields.io/pypi/status/mqttwarn.svg https://img.shields.io/pypi/v/mqttwarn.svg https://pepy.tech/badge/mqttwarn/month

GitHub | PyPI | Documentation | Issues | Changelog

About

mqttwarn - subscribe to MQTT topics and notify pluggable services.

Description

mqttwarn subscribes to any number of MQTT topics and publishes received payloads to one or more notification services after optionally applying sophisticated transformations.

A picture says a thousand words.

https://raw.githubusercontent.com/mqtt-tools/mqttwarn/main/assets/mqttwarn.png

Notification service coverage

mqttwarn comes with over 70 notification handler plugins, covering a wide range of notification services and is very open to further contributions. You can enjoy the alphabetical list of plugins on the mqttwarn notifier catalog page.

On top of that, it integrates with the excellent Apprise notification library. Apprise notification services has a complete list of the 80+ notification services supported by Apprise.

Documentation

The mqttwarn documentation is the right place to read all about mqttwarn’s features and integrations, and how you can leverage all its framework components for building custom applications. Its service plugins can be inspected on the mqttwarn notifier catalog page.

Installation

Using pip

Synopsis:

pip install --upgrade mqttwarn

You can also add support for a specific service plugin:

pip install --upgrade 'mqttwarn[xmpp]'

You can also add support for multiple services, all at once:

pip install --upgrade 'mqttwarn[apprise,asterisk,nsca,desktopnotify,tootpaste,xmpp]'

See also: Installing mqttwarn with pip.

OCI container image

For running mqttwarn on a container infrastructure like Docker or Kubernetes, corresponding images are automatically published to the GitHub Container Registry (GHCR).

  • ghcr.io/mqtt-tools/mqttwarn-standard:latest

  • ghcr.io/mqtt-tools/mqttwarn-full:latest

To learn more about this topic, please follow up reading the Using the OCI image with Docker or Podman documentation section.

Configuration

In order to learn how to configure mqttwarn, please head over to the documentation section about the mqttwarn configuration.

Usage

Interactive service

Just launch mqttwarn:

# Run mqttwarn
mqttwarn

To supply a different configuration file or log file, optionally use:

# Define configuration file
export MQTTWARNINI=/etc/mqttwarn/acme.ini

# Define log file
export MQTTWARNLOG=/var/log/mqttwarn.log

# Run mqttwarn
mqttwarn

System daemon

There are different ways to run mqttwarn as a system daemon. There are examples for systemd, traditional init, OpenRC, and Supervisor in the etc directory of this repository, for example supervisor.ini (Supervisor) and mqttwarn.service (systemd).

Standalone

In order to directly invoke notification plugins from custom programs, or for debugging them, see Running notification plugins standalone.

Development sandbox

For hacking on mqttwarn, please install it in development mode, using a mqttwarn development sandbox installation.

Project information

About

These links will guide you to the source code of mqttwarn and its documentation.

Requirements

You will need at least the following components:

  • Python 3.x or PyPy 3.x.

  • An MQTT broker. We recommend Eclipse Mosquitto.

  • For invoking specific service plugins, additional Python modules may be required. See setup.py file.

Contributing

We are always happy to receive code contributions, ideas, suggestions and problem reports from the community.

So, if you would like to contribute, you are most welcome. Spend some time taking a look around, locate a bug, design issue or spelling mistake, and then send us a pull request or create an issue.

Thank you in advance for your efforts, we really appreciate any help or feedback.

License

mqttwarn is copyright © 2014-2023 Jan-Piet Mens and contributors. All rights reserved.

It is and will always be free and open source software.

Use of the source code included here is governed by the Eclipse Public License 2.0, see LICENSE file for details. Please also recognize the licenses of third-party components.

Troubleshooting

If you encounter any problems during setup or operations or if you have further suggestions, please let us know by opening an issue on GitHub. Thank you already.

Attributions

Acknowledgements

Thanks to all the contributors of mqttwarn who helped to conceive it in one way or another. You know who you are.

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mqttwarn-0.35.0.tar.gz (978.3 kB view details)

Uploaded Source

Built Distribution

mqttwarn-0.35.0-py3-none-any.whl (117.9 kB view details)

Uploaded Python 3

File details

Details for the file mqttwarn-0.35.0.tar.gz.

File metadata

  • Download URL: mqttwarn-0.35.0.tar.gz
  • Upload date:
  • Size: 978.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for mqttwarn-0.35.0.tar.gz
Algorithm Hash digest
SHA256 3a66ec2a1aed60177973894c99125d838de1eeed1f2f1e98025d91c682091e21
MD5 b63dd8055762c389242ac4b52994fe86
BLAKE2b-256 128d86a6c5325876390966565eef5e297a66dc9aa8635605f0c94c3f7176cc21

See more details on using hashes here.

File details

Details for the file mqttwarn-0.35.0-py3-none-any.whl.

File metadata

  • Download URL: mqttwarn-0.35.0-py3-none-any.whl
  • Upload date:
  • Size: 117.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for mqttwarn-0.35.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e53523fe3bcb54681a47896cf5052c3b80117f61daea944b7a95ea44637d2771
MD5 4dbde9ace6cf4d7f60ac432e4ee0dd10
BLAKE2b-256 f0c1d7fb1d217e2df1f467fd43000c1e90f430dcd446924f92aa74ce010dd5be

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page