Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rubenhoenle/matrix-mqtt-bridge
Bridge for forwarding messages between the MQTT protocol and the Matrix messenger.
https://github.com/rubenhoenle/matrix-mqtt-bridge
docker hivemq matrix matrixbot mqtt
Last synced: about 2 months ago
JSON representation
Bridge for forwarding messages between the MQTT protocol and the Matrix messenger.
- Host: GitHub
- URL: https://github.com/rubenhoenle/matrix-mqtt-bridge
- Owner: rubenhoenle
- Created: 2023-02-01T19:15:48.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-08-04T20:08:50.000Z (5 months ago)
- Last Synced: 2024-08-04T21:57:20.030Z (5 months ago)
- Topics: docker, hivemq, matrix, matrixbot, mqtt
- Language: Python
- Homepage: https://rubenhoenle.github.io
- Size: 563 KB
- Stars: 4
- Watchers: 1
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[![CI/CD](https://github.com/rubenhoenle/Matrix-MQTT-Bridge/actions/workflows/build.yml/badge.svg)](https://github.com/rubenhoenle/Matrix-MQTT-Bridge/actions/workflows/build.yml)
# Matrix-MQTT-Bridge
> [!WARNING]
> At the moment I have no use-case for this project anymore. So this project is currently unmaintained.This project was created to create bridge between the Matrix Messenger and the MQTT protocol. I'm using this to control a microcontroller / Raspberry Pi Pico over a Matrix chat. Using this project the microcontroller is able to recieve the messages posted into the Matrix chat (like in the graphic). MQTT Messages which get published by the microcontroller get also forwarded into the Matrix chat by the Matrix-MQTT-Bridge.
![Matrix-MQTT-Bridge](docs/phone_to_pico.png?raw=true)
---
## Running the bridge
### Setup
You can run the Matrix-MQTT-Bridge via Docker, e.g. by using this `docker-compose.yaml` file. You will have to create a `config.ini` file to configure the connection to the MQTT broker and to the Matrix server. I'm using this project in combination with a **free private** [HiveMQ cloud instance](https://console.hivemq.cloud/), which acts as my MQTT broker.
```yaml
version: "3.9"services:
matrix-mqtt-bridge:
image: ghcr.io/rubenhoenle/matrix-mqtt-bridge:latest
container_name: matrix-mqtt-bridge
restart: always
volumes:
- ./config.ini:/config.ini
```---
### Config file
The `config.ini` is split into two parts: The Matrix configuration and the configuration for the MQTT connection.
#### Matrix configuration
You will need two Matrix accounts: The one you are using on e.g. your phone (I'm using my regular, personal Matrix Account for this) and this Matrix-MQTT-Bridge will require it's own account.
After you have created a seperate Matrix account for the Matrix-MQTT-Bridge, create a new chatroom and with one of your accounts and add the other account to this room.
Now, check if your able to write / recieve messages in this chatroom using your two different accounts.**Important: Matrix room has to be unencrypted. Do not enable encryption when creating the Matrix chatroom!**
#### MQTT configuration
Is actually self-explanatory. Enter your Host (for me it's my HiveMQ cloud instance), the port and the credentials to connect to the MQTT message broker (username / password).
- The `topic_sub` is the MQTT topic the Matrix-MQTT-Bridge will **subscribe** to. All MQTT messages recieved on this topic will be sent into the Matrix chatroom by the bridge.
- When the Matrix-MQTT-Bridge recieves a message via Matrix, it will publish this message to the MQTT broker using the topic specified in `topic_pub`.```ini
[MATRIX]
homeserver = https://matrix.org
user = @YOUR_USERNAME:matrix.org
password = YOUR_PASSWORD_USED_TO_LOGIN_INTO_MATRIX
room_id = !YOUR_ROOM_ID:matrix.org[MQTT]
host = YOUR_HOST.hivemq.cloud
user = YOUR_MQTT_USER
password = YOUR_MQTT_PASSWORD
port = 8883
tls = true
topic_sub = mqttbridge/sub
topic_pub = mqttbridge/pub
```---
## Development and contributing
Development is based on the [nix package manager](https://nixos.org/download/).
```bash
# launch dev shell with all dependencies installed
nix develop# format code
nix fmt# run the matrix-mqtt-bridge
nix run
```### Building and running the docker image
```bash
# build the container image
nix build .#containerImage# load the container image into docker
docker load < result# start the matrix-mqtt-bridge container
docker compose up
```