À l’écriture de cet article le projet Zigbee2MQTT supporte « officiellement » 1402 appareils de 207 fabricants ou marques.
Coté serveur (Zigbee2MQTT)
Un peu de configuration pour commencer dans le fichier configuration.yaml assurez-vous de la présence de permit_join et qu’il soit autorisé permit_join: true
nano /opt/zigbee2mqtt/data/configuration.yaml
Coté « client » (Devices)
Chaque appareil ou constructeur à sa méthode ou presque… Appuyer sur un bouton proche de la passerelle (clé USB), un « petit trou reset » à maintenir x secondes… Ou parfois, c’est encore plus amusant… Voir la vidéo reset d’une ampoule Ikea ci-dessous.
À la fin de l’appairage de vos appareils, il est important de remettre la valeur de permit_join à false permit_join: false sinon vous risquez de voir apparaitre du monde sur votre réseau.
Vous pouvez vérifier dans les logs ou via MQTT de la réussite d’un appairage.
Afin de se débarrasser des diverses passerelles IKEA, HUE, … Qui pour certaines ne sont plus maintenue par leur fabricant. Coucou Phillips. Il existe une solution, pour intégrer tout ce petit monde facilement à votre domotique en passant via MQTT.
Si tout se passe bien vous devriez avoir un retour dans votre terminal ressemblant à ça :
node-pre-gyp info ok
added 383 packages in 111.613s
Le nombre de « packages » et le temps peuvent être différents sur votre installation.
L’installation est maintenant terminée ! Il reste maintenant à passer à un peu de configuration.
Configuration
La configuration se fait via le fichier configuration.yaml dans /opt/zigbee2mqtt/data/.
nano /opt/zigbee2mqtt/data/configuration.yaml
# MQTT settings
mqtt:
# MQTT base topic for Zigbee2MQTT MQTT messages
base_topic: zigbee2mqtt
# MQTT server URL
server: 'mqtt://localhost'
# MQTT server authentication, uncomment if required:
# user: my_user
# password: my_password
Dans la configuration de base, vous pouvez configurer base_topic qui sera le « préfixe » de tout les topics MQTT provenant de Zigbee2MQTT et la configuration MQTT. Pensez à dé-commenter user et password si nécessaire.
Après avoir fini d’éditer la configuration, lancez la commande suivante afin de générer la clé du réseau.
Il est temps de tester et de démarrer Zigbee2MQTT.
cd /opt/zigbee2mqtt
npm start
Pas d’erreur ? Tout fonctionne ? CRTL + C afin d’arrêter le processus en cours.
Démarrage automatique
Afin de ne pas se soucier du lancement, nous allons mettre Zigbee2MQTT au démarrage du Raspberry Pi.
Créez le fichier de configuration systemctlzigbee2mqtt.service :
sudo nano /etc/systemd/system/zigbee2mqtt.service
Ajoutez ceci au fichier que vous venez de créer/ouvrir :
[Unit]
Description=zigbee2mqtt
After=network.target
[Service]
ExecStart=/usr/bin/npm start
WorkingDirectory=/opt/zigbee2mqtt
StandardOutput=inherit
# Or use StandardOutput=null if you don't want Zigbee2MQTT messages filling syslog, for more options see systemd.exec(5)
StandardError=inherit
Restart=always
User=pi
[Install]
WantedBy=multi-user.target
Si vous êtes sur un pi zéro jetez un œil à ce guide. Il est nécessaire de remplacer ExecStart=/usr/bin/npm start par ExecStart=/usr/local/bin/npm start
Maintenant, il suffit d’activer le service.
sudo systemctl enable zigbee2mqtt.service
Pour terminer cette partie quelques commandes utiles :
Voir le statut : systemctl status zigbee2mqtt.service
Arrêter : sudo systemctl stop zigbee2mqtt
Démarrer : sudo systemctl start zigbee2mqtt
Voir le log : sudo journalctl -u zigbee2mqtt.service -f
Conclusion
La partie installation est terminée. Vous trouverez plus d’informations dans les sources ci-dessous. La prochaine étape sera l’appairage des différents appareils Zigbee. Comme d’habitude vous avez mes réseaux sociaux et maintenant le Discord ioodyme ainsi que le tout nouveau groupe Telegram.
Vous devriez maintenant avoir un README.md (qui lit les readme ?) et un simple camera.sh. Voyons ce que contient ce camera.sh, c’est très KISS.
C’est simplement un script qui tue les screens et les relances selon la configuration de votre cron. Pourquoi cela ? Nous avons remarqué qu’au bout d’un certain temps, la lecture prenait du retard sur le live sans trop comprendre pourquoi. Alors en cas de doute, reboot.