Le plugin jMQTT permet de connecter Jeedom à un ou plusieurs serveurs MQTT (appelé Broker) afin de recevoir les messages souscrits et de publier ses propres messages. Ses principales fonctionnalités sont :
et encore beaucoup d’autres…
MQTT, pour “Message Queuing Telemetry Transport”, est un protocole open source de messagerie qui assure des communications non permanentes entre des appareils par le transport de leurs messages.
Il a été créé en 1999 par Andy Stanford-Clark, ingénieur chez IBM, et Arlen Nipper, chez EuroTech, principalement dans la communication M2M pour permettre à deux appareils utilisant des technologies différentes de communiquer. “Devenu une norme ISO en 2016, MQTT connectait déjà à cette date des millions d’appareils dans le monde entier, dans toutes sortes d’applications et d’industries. C’est une technologie d’avenir”, affirme Fabien Pereira Vaz, technical sales manager chez Paessler AG.
Les géants du web parmi lesquels AWS ou Microsoft utilisent MQTT pour remonter les données sur leur plateforme cloud.
MQTT est un protocole de Publication/Souscription qui est léger, ouvert, simple. Il apporte une très grande souplesse dans les échanges d’information entre capteurs/actionneurs/systèmes domotique/etc.
Pour comprendre MQTT rapidement, je vous conseille cette vidéo de 4 minutes qui explique les principes de base :
Crédit : François Riotte
Pour en savoir plus, ça se passe en anglais par ici : MQTT Essentials.
Par défaut, jMQTT installe le Broker Mosquitto sur la machine hébergeant Jeedom. Il vous suffira ensuite de configurer vos modules domotique compatible MQTT pour qu’ils se connectent à ce Broker (IP de votre Jeedom).
La configuration jMQTT est alors très simple:
Important Pour ne pas installer le Broker Mosquitto sur la machine hébergeant Jeedom, commencer par décocher la case Installer Mosquitto localement, sans oublier de sauvegarder la configuration.
Après installation du plugin, il suffit de l’activer. Celui-ci prend quelques minutes pour installer les dépendances. Le suivi détaillé de la progression est possible via le log jMQTT_dep
.
Le reste de la configuration principale est assez sommaire :
C’est aussi sur cette page qu’il est possible d’ajouter et de supprimer des certificats SSL pour les Broker.
Le plugin jMQTT est disponible dans le menu : Plugins → Protocole domotique → jMQTT
.
jMQTT posséde 2 types d’équipements:
Le panneau supérieur gauche, intitulé Gestion plugin et Broker, permet de configurer le plugin, et de lister les équipements Broker.
Sur les équipements Broker, un point de couleur indique l’état de la connexion au Broker :
Ensuite, pour chaque Broker, un panneau présente les équipements connectés à celui-ci.
Se trouve également sur ce panneau :
Un équipement :
Dans la page de Gestion des équipements, cliquer sur le bouton + Ajouter un Broker et saisir son nom.
Suite à sa création, un message indique que la commande status a été ajoutée à l’équipement. Celle-ci donne l’état de connexion au Broker MQTT de l’équipement Broker. Elle prend 2 valeurs : online et offline. Elle est publiée de manière persistante auprès du Broker. Cet état permet à un équipement externe à Jeedom de connaitre son statut de connexion. Il peut aussi servir en interne Jeedom pour monitorer la connexion au Broker via un scénario.
Par défaut, un équipement Broker est configuré pour s’inscrire au Broker Mosquitto installé localement. Si cette configuration convient, activer l’équipement et sauvegarder. Revenir sur l’onglet Broker, le status du démon devrait passer à OK.
Pour modifier les informations de connexion au Broker, les paramètres sont:
Attention: L’identifiant de connexion doit être unique par client par Broker. Sinon les clients portant le même identifiant vont se déconnecter mutuellement.
Une aide contextuelle est également disponible pour chaque champ. La sauvegarde de la configuration relance le démon et la souscription au Broker MQTT avec les nouveaux paramètres.
Info
Chaque équipement Broker possède son propre fichier de log suffixé par le nom de l’équipement. Si l’équipement est renommé, le fichier de log le sera également.
Le mode inclusion automatique permet la découverte et la création automatique des équipements. Il s’active, pour le Broker concerné, en cliquant sur le bouton Mode inclusion. Il se désactive en recliquant sur le même bouton, ou automatiquement après 2 à 3 min.
Le plugin souscrit auprès du Broker le topic configuré dans l’onglet Broker (# par défaut, i.e. tous les topics) de l’équipement Broker concerné. A réception d’un message auquel aucun équipement n’a souscrit, le plugin crée automatiquement un équipement associé au topic de premier niveau.
Prenons comme exemple les messages MQTT suivants :
boiler/brand "viesmann"
boiler/burner 0
boiler/temp 70.0
A l’arrivée du premier message, le plugin crée automatiquement un équipement nommé boiler. Nous verrons dans la section Onglet Commandes que, par défaut, il créé aussi les informations associées à chaque message.
Tip
Le mode inclusion automatique des équipements n’influe que sur la création de l’équipement, et pas sur la création des informations associées, qui dépend du paramètre Ajout automatique des commandes que nous verrons dans le chapitre suivant.
Note
Une fois les équipements découverts, il est conseillé de quitter le mode automatique pour éviter la création d’équipements non souhaités, notamment dans les situations suivantes : publication de messages (si un équipement Broker reste souscrit à tous les topics, il écoutera ses propres publications), essais avec le Broker, tests de nouveaux équipements, …
Dans le premier onglet d’un équipement jMQTT, nous trouvons les paramètres communs aux autres équipements Jeedom, ainsi que cinq paramètres spécifiques au plugin :
Broker associé : Broker auquel est associé l’équipement. Attention: ne modifier ce paramètre qu’en sachant bien ce que vous faites ;
Inscrit au Topic : topic de souscription auprès du Broker MQTT. Pour un équipement de type Broker, ce paramètre n’est pas modifiable, il est imposé par l’Identifiant de Connexion au Broker, voir Onglet Broker ;
Ajout automatique des commandes : si coché, les commandes de type information seront automatiquement créés par le plugin, et l’équipement apparaitra avec une petite icône d’inclusion superposé dans la page de Gestion des équipements. La case est cochée par défaut ;
Qos : qualité de service souscrit ;
Type d’alimentation : paramètre libre vous permettant de préciser le type d’alimentation de l’équipement (non disponible pour un équipement Broker) ;
Commande d’état de la batterie : commande de l’équipement qui sera utilisée comme niveau de batterie. Si la commande info est de type binaire, alors la valeur de la batterie sera 10% (0) ou 100% (1). Si la commande info est de type numérique, alors la valeur sera utilisée comme pourcentage de batterie (non disponible pour un équipement Broker) ;
Commande de disponibilité : commande de l’équipement (info binaire) qui sera utilisée comme état de disponibilité de l’équipement. Si cette commande est à 0, alors l’équipement sera remonté en erreur “Danger” (non disponible pour un équipement Broker) ;
Dernière communication : date de dernière communication avec le Broker MQTT, que ce soit en réception (commande information) ou publication (commande action) ;
Catégorie du topic : sélection d’une image spécifique à l’équipement. Pour un équipement Broker, ce paramètre n’est pas disponible car l’image est imposée.
Important
Une fois les commandes créées, il est conseillé de décocher la case Ajout automatique des commandes pour éviter la création d’informations non souhaitées.
Concernant les boutons en haut à droite :
Appliquer template
permet d’Appliquer un template existant à l’équipement en cours ;Créer template
permet de Créer un template à partir de l’équipement en cours ;Modifier Topics
permet de Modifier en masse tous les topics de l’équipement courant (pensez à sauvegarder l’équipement après la modification) ;Dupliquer
permet de Dupliquer un équipement.Les commandes de type information (informations dans la suite) sont créés, automatiquement, uniquement si la case Ajout automatique des commandes de l’Onglet Equipement est cochée : lorsque le plugin reçoit un message dont le topic correspond au topic de souscription, il créé alors la commande correspondante lorsque celle-ci est nouvelle.
Voyons cela sur des exemples en fonction du type de payload.
Payload simple
Reprenons l’exemple de la payload MQTT publiant les messages simples suivants :
boiler/brand "viesmann"
boiler/burner 0
boiler/temp 70.0
boiler/ext_temp 19.3
boiler/hw/setpoint 50
boiler/hw/temp 49.0
Le plugin créé les informations suivantes :
Nom | Sous-Type | Topic | Valeur |
---|---|---|---|
brand | info | boiler/brand | viesmann |
burner | info | boiler/burner | 0 |
temp | info | boiler/temp | 70.0 |
ext_temp | info | boiler/ext_temp | 19.3 |
hw:setpoint | info | boiler/hw/setpoint | 50 |
hw:temp | info | boiler/hw/temp | 49.0 |
Note
- Le nom de la commande est initialisé automatiquement par le plugin à partir du topic. Il peut ensuite être modifié comme souhaité.
- Jeedom limite la longueur des noms de commande à 127 caractères depuis la version 4.1.17, 45 caractères avant. Dans le cas de commandes de longueur supérieure, jMQTT remplace leurs noms par leur code de hashage md4 sur 32 caractères (par exemple 5182636929901af7fa5fd97da5e279e1). L’utilisateur devra alors remplacer ces noms par le nommage de son choix.
- Lorsqu’un Payload binaire (ne correspondant pas à du texte) est reçu, jMQTT essaye dans un premier temps de le décompresser en zlib et de le convertir en texte. S’il n’y parvient pas ou que le résultat reste binaire, alors cette valeur binaire est envoyée envoyée dans la commande information encodée en base64.
Payload JSON
Dans le cas d’une payload JSON, le plugin sait décoder le contenu et créer les informations associées, et ceci indépendamment de l’état de la case Ajout automatique des commandes de l’Onglet Equipement.
Le champ “Chemin JSON” est utilisé pour sélectionner l’information à extraire. Il s’agit d’un chemin JSON suivant le format JSONPath, à travers l’implémentation de Galbar. Ce format est un outil très puissant pour analyser, transformer et extraire sélectivement des données à partir de structures JSON, à l’image de XPath pour le XML.
Voici un aperçu du langage et des possibilités qu’il renferme :
JSONPath | Description |
---|---|
$ | Objet/élément racine |
@ | Objet/élément courant |
. or [] | Operateur de sélection d’un enfant |
.. | Descente récursive |
* | Caractère générique : tous les objets/éléments indépendamment de leurs noms |
[] | Opérateur d’indice : opérateur natif d’un tableau |
[,] | Opérateur d’union : noms alternatifs ou indices de tableau en tant qu’ensemble |
[start:end:step] | Opérateur de découpage de tableau |
?() | Expression (script) de filtrage de données |
Le premier caractère ‘$’ est omis par la vue JSON de jMQTT dans un souci de lisibilité, mais le Chemin JSON reste parfaitement fonctionnel que le caractère ‘$’ soit présent ou non.
Prenons l’exemple de la payload JSON suivante :
esp/temperatures {"device": "ESP32", "sensorType": "Temp", "values": [9.5, 18.2, 20.6]}
Au premier message reçu, jMQTT créé automatiquement l’information suivante :
Nom | Sous-Type | Topic | Chemin JSON | Valeur |
---|---|---|---|---|
temperatures | info | esp/temperatures | {“device”: “ESP32”, “sensorType”: “Temp”, “values”: [9.5, 18.2, 20.6]} |
En basculant dans la vue JSON, via le bouton dédié en haut à droite de la page, et en dépliant complètement l’arbre manuellement, nous obtenons :
# | Nom | Sous-Type | Topic | Chemin JSON | Valeur | |
---|---|---|---|---|---|---|
> | temperatures | info | esp/temperatures | {“device”: “ESP32”, “sensorType”: “Temp”, “values”: [9.5, 18.2, 20.6]} | ||
info | esp/temperatures | [device] | “ESP32” | |||
info | esp/temperatures | [sensorType] | “Temp” | |||
> | info | esp/temperatures | [values] | [9.5, 18.2, 20.6] | ||
info | esp/temperatures | [values][0] | 9.5 | |||
info | esp/temperatures | [values][1] | 18.2 | |||
info | esp/temperatures | [values][2] | 20.6 |
Seule la première ligne est une commande, reconnaissable parce qu’elle a un id, un nom et des paramètres.
Pour créer des commandes associées à chaque température, il suffit de saisir un nom dans chaque commande (par exemple temp0, temp1 et temp2) et de sauvegarder.
L’affichage bascule dans la vue normale, montrant toutes les commandes de l’équipement ; dans notre cas :
Nom | Sous-Type | Topic | Chemin JSON | Valeur |
---|---|---|---|---|
temp0 | info | esp/temperatures | [values][0] | 9.5 |
temp1 | info | esp/temperatures | [values][1] | 18.2 |
temp2 | info | esp/temperatures | [values][2] | 20.6 |
temperatures | info | esp/temperatures | {“device”: “ESP32”, “sensorType”: “Temp”, “values”: [9.5, 18.2, 20.6]} |
Si nous rebasculons dans la vue JSON, nous obtenons alors :
# | Nom | Sous-Type | Topic | Chemin JSON | Valeur | |
---|---|---|---|---|---|---|
> | temperatures | info | esp/temperatures | {“device”: “ESP32”, “sensorType”: “Temp”, “values”: [9.5, 18.2, 20.6]} | ||
info | esp/temperatures | [device] | “ESP32” | |||
info | esp/temperatures | [sensorType] | “Temp” | |||
> | info | esp/temperatures | [values] | [9.5, 18.2, 20.6] | ||
temp0 | info | esp/temperatures | [values][0] | 9.5 | ||
temp1 | info | esp/temperatures | [values][1] | 18.2 | ||
temp2 | info | esp/temperatures | [values][2] | 20.6 |
Note
- Le nom des commandes peut être modifié comme souhaité, jMQTT se base sur le champ Topic pour associer la bonne valeur.
- Une fois les commandes filles d’une commande JSON créé, il est possible de supprimer la commande mère sans affecter la mise à jour des commandes filles.
Les commandes de type action permettent au plugin jMQTT de publier des messages vers le Broker MQTT. Pour cela, créer une commande via le bouton + Ajouter une commande action et remplir les champs selon le besoin :
Sous-type Défaut
Les exemples du tableau suivant :
Publieront respectivement :
hw/setpoint/set 40
hw/set {"name": "setpoint", "value": 40}
hw/set {"name": "setpoint", "value": 45}
En supposant que #[home][boiler][hw_setpoint]#
a pour valeur 45.
Sous-type Curseur
Les configurations suivantes publieront la valeur saisie via un widget de type curseur :
Soit respectivement, en supposant que la valeur du curseur est 50 :
hw/setpoint/set 50
hw/set {"name": "setpoint", "value": 50}
Note
Pour configurer les valeurs min/max de la jauge affichée pour une commande slider, éditer les paramètres avancés de la commande slider (la roue crantée à gauche du bouton Tester), aller dans l’onglet Affichage et ajouter minValue et maxValue dans la section Paramètres optionnels widget (cette configuration est apportée par le core de Jeedom, elle n’est pas spécifique à jMQTT).
Sous-type Message
Pour un message dont le titre est ecs
et le contenu est 50
, la configuration ci-après publiera :
boiler {"setpoint": "ecs", "value": 50}
Sous-type Couleur
La configuration suivante publiera le code couleur sélectionnée via un widget sélecteur de couleur :
Publiera pour une couleur rouge clair selectionnée :
room/lamp/color #e63939
Deux boutons en haut à droite de la page permettent de choisir entre 2 types du vue :
Il est aussi possible de créer manuellement des équipements jMQTT. Cliquer sur le bouton + et saisir le nom de l’équipement. Dans la page Onglet Equipement, le topic de souscription définit les informations qui seront souscrites par l’équipement.
Pour plus d’information sur les topics MQTT, nous conseillons la lecture de MQTT Essentials Part 5: MQTT Topics & Best Practices.
Un équipement peut être dupliqué via le bouton Dupliquer
situé en haut à gauche de la page de configuration de l’équipement.
Une boite de dialogue demande le nom du nouvel équipement. Sont dupliqués :
Important
Le topic des commandes dupliquées de type action doit être modifié manuellement.
Note
Les commandes de type info ne sont pas dupliquées. Elles seront découvertes automatiquement après définition du topic de souscription et activation de l’équipement, si la case Ajout automatique des commandes est cochée.
Le bouton Santé, présent dans la page de Gestion des équipements, permet d’afficher une vue de la santé des Broker et des équipements :
Les informations présentes sont : le nom, l’ID, le Topic de souscription, la date de Dernière communication, la Date de création et l’état des Brokers (Activation et communication, Visibilité et Auto inclusion) ainsi que des équipements (Activation, Visibilité, Inclusion automatique, Batterie et Disponibilité).
jMQTT met à disposition de l’utilisateur une solution simple pour appliquer un modèle prédéfini (template) à un équipement. Les templates conservent toutes les commandes d’origine, leurs configurations et leurs paramètres avancés.
Dans un permier temps, il est possible de créer ou d’appliquer un template à un équipement existant, celà se passe directement sur un équipement :
Ensuite, le gestionnaire de Template est présent dans la section Gestion plugin et brokers du plugin :
Il permet d’ajouter, de télécharger et de supprimer des templates et d’en visualiser les commandes.
Dans le gestionnaire, on distingue différentes sections :
Ceux préfixés par [Perso]
sont liés à votre installation, les autres arrivent directement avec jMQTT.
Si vous souhaitez mettre à disposition vos templates, n’hésitez pas à ouvrir un ticket sur GitHub.
Lorsqu’un template est selectionné dans la liste, la partie de droite est renseignée :
Perso
).La seule information à renseigner est le nom que vous souhaitez donner à votre template.
Une fois la fenêtre validée, un nouveau template est disponible sur le système et peut être utilisé.
Quand on souhaite appliquer un template, 3 informations sont attendues :
Une fois la fenêtre validée, l’équipement est modifié et peut être utilisé.
L’objectif du MQTTS (Chiffrement des flux MQTT en TLS) est d’établir une communication chiffrée de bout en bout entre un Broker et des clients MQTTS, afin de garantir la confidentialité des échanges.
Il existe de nombreux Broker MQTT gratuits ou payants disponibles en ligne pour connecter un large ensemble d’équipements IoT, par exemple :
La grande majorité de ces Broker ne supportent pas de communication “en clair” sur Internet, et demandent la connexion via MQTT over TLS ou MQTTS. Cela est tout à fait compréhensible, car “en clair” n’importe qui peut en lire le contenu des messages, ou pire, envoyer des messages/ordres à votre place.
Il est aussi possible de configurer son propre Broker pour supporter le MQTTS. A ce sujet, je vous renvoie vers l’excellent article MQTTS : Comment utiliser MQTT avec TLS ? [Version en cache], l’auteur, Julien Grossholtz, n’est nullement associé au plugin jMQTT ou à Jeedom. Il s’agit d’une opération complexe, réservé à ceux qui en comprennent les implications et savent utiliser les Certificats.
Depuis mai 2021, jMQTT supporte la connexion aux Broker publique ou privé en MQTTS. Est aussi implémenté un mecanisme de validation du Certificat du Serveur et l’emploi une paire de clés cryptographique personnalisée (Certificat & Clé Privée Client) pour un chiffrement asymétrique de bout en bout.
Il peut arriver que l’installation du plugin se bloque. Cela se produit si le serveur est relancé pendant l’installation (voir log jMQTT_dep
).
Pour se débloquer, se connecter au Jeedom et supprimer le fichier /tmp/jeedom/jMQTT/progress_dep.txt
.
Si vous changiez le niveau de log, le démon devait être relancé dans les anciennes version. Pour cela, il fallait désactiver puis réactiver l’équipement Broker concerné. Aujourd’hui, le démon est automatiquement informé que le niveau de log a changé et les nouveaux logs arrivent.
Vérifier qu’il n’y a pas 2 clients ayant le même identifiant, voir Identifiant de Connexion dans l’onglet Broker de l’équipement Broker concerné.
Les problèmes en cours d’investigation sont sur GitHub : Issues jMQTT.
En cas de problèmes à l’installation, fournir les fichiers de log jMQTT (niveau Debug) et jMQTT_dep.
En cas de problèmes à l’utilisation, passer le plugin et les Broker en niveau de log Debug
reproduire le problème et fournir :
jMQTT
,/tmp/diag_jmqtt.log
) : mosquitto_sub -h localhost -v -t "#" | xargs -d$'\n' -L1 bash -c 'date "+%Y-%m-%d %T.%3N $0"' | tee /tmp/diag_jmqtt.log
En remplaçant, si besoin, localhost
par le nom ou l’IP de la machine hébergeant le Broker MQTT.
Si une authentification est requise, ajouter -u username
et -p password
avant le -v
.
Supposons un équipement virtuel, appelé Saison Virtuel, dont une commande action de sous-type Liste permette de définir la saison (été, hiver). L’objectif est de pouvoir définir cette saison via un message MQTT envoyé par une application externe.
Supposons donc également un équipement jMQTT que nous aurons créé, appelé Saison_jMQTT, souscrivant au topic saison/#
, dont une commande info est saison/set
.
Nous souhaitons que lorsqu’une application publie le message saison/set hiver
sur le Broker, la commande info saison du virtuel soit mise à jour avec hiver.
Pour ce faire, il faut créer une deuxième commande action côté virtuel (commande set_saison ci-dessous) qui mette à jour l’information saison du virtuel à partir de celle de l’équipement jMQTT. Le virtuel est donc configuré comme ceci :
Côté équipement jMQTT, nous avons la configuration simple suivante :
Ensuite, il y a deux solutions pour lier les commandes :
Créer un scénario avec la commande info [Saison jMQTT][set]
comme déclencheur, qui exécuterait la commande action [Saison Virtuel][set_saison]
; ou
Configurer une action sur valeur en cliquant sur la roue crantée à droite de la commande info [Saison jMQTT][set]
, onglet Configuration:
Attention, quel que soit la solution, il est important de configurer la Gestion de la répétition des valeurs de la commande info [Saison jMQTT][set]
à Toujours répéter pour que toutes les valeurs remontent au virtuel. Pour cela, toujours en cliquant sur la roue crantée à droite de cette dernière, onglet Configuration: