From 97100b0fd81fb9c6edfbf6a1bacf99158952c44c Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Sun, 19 Sep 2021 08:35:22 +0200
Subject: [PATCH 1/9] Zigbee2mqtt remove device list
---
server/services/zigbee2mqtt/model/AXIS.js | 15 -
server/services/zigbee2mqtt/model/Adeo.js | 17 --
.../services/zigbee2mqtt/model/AduroSmart.js | 16 --
server/services/zigbee2mqtt/model/Airam.js | 16 --
server/services/zigbee2mqtt/model/Anchor.js | 15 -
server/services/zigbee2mqtt/model/Belkin.js | 15 -
server/services/zigbee2mqtt/model/Bitron.js | 18 --
.../services/zigbee2mqtt/model/Blaupunkt.js | 15 -
server/services/zigbee2mqtt/model/Bosch.js | 16 --
server/services/zigbee2mqtt/model/Calex.js | 16 --
.../services/zigbee2mqtt/model/Centralite.js | 15 -
server/services/zigbee2mqtt/model/Climax.js | 17 --
.../zigbee2mqtt/model/CommercialElectric.js | 15 -
server/services/zigbee2mqtt/model/Danalock.js | 15 -
.../zigbee2mqtt/model/DresdenElektronik.js | 16 --
server/services/zigbee2mqtt/model/EDP.js | 16 --
server/services/zigbee2mqtt/model/ELKO.js | 15 -
server/services/zigbee2mqtt/model/EcoSmart.js | 18 --
.../services/zigbee2mqtt/model/Eurotronic.js | 15 -
server/services/zigbee2mqtt/model/GE.js | 19 --
.../zigbee2mqtt/model/GMYSmartBulb.js | 15 -
server/services/zigbee2mqtt/model/Gira.js | 15 -
server/services/zigbee2mqtt/model/Gledopto.js | 26 --
server/services/zigbee2mqtt/model/HEIMAN.js | 27 --
.../services/zigbee2mqtt/model/HamptonBay.js | 15 -
server/services/zigbee2mqtt/model/Hive.js | 19 --
server/services/zigbee2mqtt/model/Honyar.js | 15 -
server/services/zigbee2mqtt/model/IKEA.js | 43 ---
.../services/zigbee2mqtt/model/Iluminize.js | 15 -
server/services/zigbee2mqtt/model/Immax.js | 15 -
server/services/zigbee2mqtt/model/Innr.js | 42 ---
server/services/zigbee2mqtt/model/Iris.js | 17 --
server/services/zigbee2mqtt/model/JIAWEN.js | 15 -
server/services/zigbee2mqtt/model/KeenHome.js | 16 --
.../zigbee2mqtt/model/KsentryElectronics.js | 15 -
.../services/zigbee2mqtt/model/Leedarson.js | 17 --
server/services/zigbee2mqtt/model/Lidl.js | 25 --
.../services/zigbee2mqtt/model/LivingWise.js | 16 --
server/services/zigbee2mqtt/model/Livolo.js | 15 -
server/services/zigbee2mqtt/model/Lonsonho.js | 16 --
server/services/zigbee2mqtt/model/Lupus.js | 16 --
server/services/zigbee2mqtt/model/Meazon.js | 16 --
.../services/zigbee2mqtt/model/MullerLicht.js | 17 --
server/services/zigbee2mqtt/model/NET2GRID.js | 15 -
server/services/zigbee2mqtt/model/Nanoleaf.js | 15 -
server/services/zigbee2mqtt/model/Netvox.js | 15 -
.../services/zigbee2mqtt/model/NinjaBlocks.js | 15 -
server/services/zigbee2mqtt/model/Nue_3A.js | 31 --
server/services/zigbee2mqtt/model/Nyce.js | 18 --
server/services/zigbee2mqtt/model/ORVIBO.js | 15 -
server/services/zigbee2mqtt/model/OSRAM.js | 37 ---
server/services/zigbee2mqtt/model/Oujiabao.js | 15 -
.../services/zigbee2mqtt/model/PaulNeuhaus.js | 17 --
server/services/zigbee2mqtt/model/Paulmann.js | 18 --
server/services/zigbee2mqtt/model/Philips.js | 51 ----
server/services/zigbee2mqtt/model/RGBGenie.js | 15 -
server/services/zigbee2mqtt/model/ROBB.js | 15 -
server/services/zigbee2mqtt/model/SONOFF.js | 18 --
server/services/zigbee2mqtt/model/Salus.js | 15 -
server/services/zigbee2mqtt/model/Securifi.js | 15 -
server/services/zigbee2mqtt/model/Sengled.js | 21 --
server/services/zigbee2mqtt/model/Sercomm.js | 15 -
.../zigbee2mqtt/model/ShenzhenHoma.js | 17 --
.../zigbee2mqtt/model/SmartHomePty.js | 16 --
.../services/zigbee2mqtt/model/SmartThings.js | 29 --
server/services/zigbee2mqtt/model/Stelpro.js | 15 -
.../services/zigbee2mqtt/model/Sunricher.js | 15 -
server/services/zigbee2mqtt/model/Swann.js | 16 --
server/services/zigbee2mqtt/model/Sylvania.js | 25 --
server/services/zigbee2mqtt/model/TUYATEC.js | 15 -
.../zigbee2mqtt/model/ThirdReality.js | 15 -
server/services/zigbee2mqtt/model/Trust.js | 18 --
server/services/zigbee2mqtt/model/TuYa.js | 21 --
server/services/zigbee2mqtt/model/Visonic.js | 16 --
server/services/zigbee2mqtt/model/Xiaomi.js | 45 ---
server/services/zigbee2mqtt/model/Yale.js | 18 --
server/services/zigbee2mqtt/model/eCosy.js | 15 -
server/services/zigbee2mqtt/model/iCasa.js | 15 -
server/services/zigbee2mqtt/model/ilux.js | 15 -
server/services/zigbee2mqtt/model/index.js | 102 -------
server/services/zigbee2mqtt/utils/features.js | 272 ------------------
.../zigbee2mqtt/utils/loadFeatures.js | 33 ---
.../zigbee2mqtt/utils/loadFeatures.test.js | 59 ----
83 files changed, 1936 deletions(-)
delete mode 100644 server/services/zigbee2mqtt/model/AXIS.js
delete mode 100644 server/services/zigbee2mqtt/model/Adeo.js
delete mode 100644 server/services/zigbee2mqtt/model/AduroSmart.js
delete mode 100644 server/services/zigbee2mqtt/model/Airam.js
delete mode 100644 server/services/zigbee2mqtt/model/Anchor.js
delete mode 100644 server/services/zigbee2mqtt/model/Belkin.js
delete mode 100644 server/services/zigbee2mqtt/model/Bitron.js
delete mode 100644 server/services/zigbee2mqtt/model/Blaupunkt.js
delete mode 100644 server/services/zigbee2mqtt/model/Bosch.js
delete mode 100644 server/services/zigbee2mqtt/model/Calex.js
delete mode 100644 server/services/zigbee2mqtt/model/Centralite.js
delete mode 100644 server/services/zigbee2mqtt/model/Climax.js
delete mode 100644 server/services/zigbee2mqtt/model/CommercialElectric.js
delete mode 100644 server/services/zigbee2mqtt/model/Danalock.js
delete mode 100644 server/services/zigbee2mqtt/model/DresdenElektronik.js
delete mode 100644 server/services/zigbee2mqtt/model/EDP.js
delete mode 100644 server/services/zigbee2mqtt/model/ELKO.js
delete mode 100644 server/services/zigbee2mqtt/model/EcoSmart.js
delete mode 100644 server/services/zigbee2mqtt/model/Eurotronic.js
delete mode 100644 server/services/zigbee2mqtt/model/GE.js
delete mode 100644 server/services/zigbee2mqtt/model/GMYSmartBulb.js
delete mode 100644 server/services/zigbee2mqtt/model/Gira.js
delete mode 100644 server/services/zigbee2mqtt/model/Gledopto.js
delete mode 100644 server/services/zigbee2mqtt/model/HEIMAN.js
delete mode 100644 server/services/zigbee2mqtt/model/HamptonBay.js
delete mode 100644 server/services/zigbee2mqtt/model/Hive.js
delete mode 100644 server/services/zigbee2mqtt/model/Honyar.js
delete mode 100644 server/services/zigbee2mqtt/model/IKEA.js
delete mode 100644 server/services/zigbee2mqtt/model/Iluminize.js
delete mode 100644 server/services/zigbee2mqtt/model/Immax.js
delete mode 100644 server/services/zigbee2mqtt/model/Innr.js
delete mode 100644 server/services/zigbee2mqtt/model/Iris.js
delete mode 100644 server/services/zigbee2mqtt/model/JIAWEN.js
delete mode 100644 server/services/zigbee2mqtt/model/KeenHome.js
delete mode 100644 server/services/zigbee2mqtt/model/KsentryElectronics.js
delete mode 100644 server/services/zigbee2mqtt/model/Leedarson.js
delete mode 100644 server/services/zigbee2mqtt/model/Lidl.js
delete mode 100644 server/services/zigbee2mqtt/model/LivingWise.js
delete mode 100644 server/services/zigbee2mqtt/model/Livolo.js
delete mode 100644 server/services/zigbee2mqtt/model/Lonsonho.js
delete mode 100644 server/services/zigbee2mqtt/model/Lupus.js
delete mode 100644 server/services/zigbee2mqtt/model/Meazon.js
delete mode 100644 server/services/zigbee2mqtt/model/MullerLicht.js
delete mode 100644 server/services/zigbee2mqtt/model/NET2GRID.js
delete mode 100644 server/services/zigbee2mqtt/model/Nanoleaf.js
delete mode 100644 server/services/zigbee2mqtt/model/Netvox.js
delete mode 100644 server/services/zigbee2mqtt/model/NinjaBlocks.js
delete mode 100644 server/services/zigbee2mqtt/model/Nue_3A.js
delete mode 100644 server/services/zigbee2mqtt/model/Nyce.js
delete mode 100644 server/services/zigbee2mqtt/model/ORVIBO.js
delete mode 100644 server/services/zigbee2mqtt/model/OSRAM.js
delete mode 100644 server/services/zigbee2mqtt/model/Oujiabao.js
delete mode 100644 server/services/zigbee2mqtt/model/PaulNeuhaus.js
delete mode 100644 server/services/zigbee2mqtt/model/Paulmann.js
delete mode 100644 server/services/zigbee2mqtt/model/Philips.js
delete mode 100644 server/services/zigbee2mqtt/model/RGBGenie.js
delete mode 100644 server/services/zigbee2mqtt/model/ROBB.js
delete mode 100644 server/services/zigbee2mqtt/model/SONOFF.js
delete mode 100644 server/services/zigbee2mqtt/model/Salus.js
delete mode 100644 server/services/zigbee2mqtt/model/Securifi.js
delete mode 100644 server/services/zigbee2mqtt/model/Sengled.js
delete mode 100644 server/services/zigbee2mqtt/model/Sercomm.js
delete mode 100644 server/services/zigbee2mqtt/model/ShenzhenHoma.js
delete mode 100644 server/services/zigbee2mqtt/model/SmartHomePty.js
delete mode 100644 server/services/zigbee2mqtt/model/SmartThings.js
delete mode 100644 server/services/zigbee2mqtt/model/Stelpro.js
delete mode 100644 server/services/zigbee2mqtt/model/Sunricher.js
delete mode 100644 server/services/zigbee2mqtt/model/Swann.js
delete mode 100644 server/services/zigbee2mqtt/model/Sylvania.js
delete mode 100644 server/services/zigbee2mqtt/model/TUYATEC.js
delete mode 100644 server/services/zigbee2mqtt/model/ThirdReality.js
delete mode 100644 server/services/zigbee2mqtt/model/Trust.js
delete mode 100644 server/services/zigbee2mqtt/model/TuYa.js
delete mode 100644 server/services/zigbee2mqtt/model/Visonic.js
delete mode 100644 server/services/zigbee2mqtt/model/Xiaomi.js
delete mode 100644 server/services/zigbee2mqtt/model/Yale.js
delete mode 100644 server/services/zigbee2mqtt/model/eCosy.js
delete mode 100644 server/services/zigbee2mqtt/model/iCasa.js
delete mode 100644 server/services/zigbee2mqtt/model/ilux.js
delete mode 100644 server/services/zigbee2mqtt/model/index.js
delete mode 100644 server/services/zigbee2mqtt/utils/features.js
delete mode 100644 server/services/zigbee2mqtt/utils/loadFeatures.js
delete mode 100644 server/test/services/zigbee2mqtt/utils/loadFeatures.test.js
diff --git a/server/services/zigbee2mqtt/model/AXIS.js b/server/services/zigbee2mqtt/model/AXIS.js
deleted file mode 100644
index ad300030f1..0000000000
--- a/server/services/zigbee2mqtt/model/AXIS.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * AXIS managed models.
- */
-const AXIS = {
- brand: 'AXIS',
- models: {
- 'GR-ZB01-W': [features.door], // curtain / shuttle
- },
-};
-
-module.exports = {
- AXIS,
-};
diff --git a/server/services/zigbee2mqtt/model/Adeo.js b/server/services/zigbee2mqtt/model/Adeo.js
deleted file mode 100644
index df787d860a..0000000000
--- a/server/services/zigbee2mqtt/model/Adeo.js
+++ /dev/null
@@ -1,17 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Adeo managed models.
- */
-const Adeo = {
- brand: 'Adeo',
- models: {
- '9CZA-A806ST-Q1A': [features.light, features.brightness, features.color_temperature, features.color],
- '9CZA-M350ST-Q1A': [features.light, features.brightness, features.color_temperature, features.color],
- '9CZA-G1521-Q1A': [features.light, features.brightness, features.color_temperature, features.color],
- },
-};
-
-module.exports = {
- Adeo,
-};
diff --git a/server/services/zigbee2mqtt/model/AduroSmart.js b/server/services/zigbee2mqtt/model/AduroSmart.js
deleted file mode 100644
index 062761fc3a..0000000000
--- a/server/services/zigbee2mqtt/model/AduroSmart.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * AduroSmart managed models.
- */
-const AduroSmart = {
- brand: 'AduroSmart',
- models: {
- '81809': [features.light, features.brightness, features.color_temperature, features.color],
- '81825': [features.switch_sensor],
- },
-};
-
-module.exports = {
- AduroSmart,
-};
diff --git a/server/services/zigbee2mqtt/model/Airam.js b/server/services/zigbee2mqtt/model/Airam.js
deleted file mode 100644
index 319ac33644..0000000000
--- a/server/services/zigbee2mqtt/model/Airam.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Airam managed models.
- */
-const Airam = {
- brand: 'Airam',
- models: {
- '4713407': [features.light, features.brightness],
- 'AIRAM-CTR.U': [features.switch_sensor],
- },
-};
-
-module.exports = {
- Airam,
-};
diff --git a/server/services/zigbee2mqtt/model/Anchor.js b/server/services/zigbee2mqtt/model/Anchor.js
deleted file mode 100644
index dbd130523e..0000000000
--- a/server/services/zigbee2mqtt/model/Anchor.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Anchor managed models.
- */
-const Anchor = {
- brand: 'Anchor',
- models: {
- '67200BL': [features.switch],
- },
-};
-
-module.exports = {
- Anchor,
-};
diff --git a/server/services/zigbee2mqtt/model/Belkin.js b/server/services/zigbee2mqtt/model/Belkin.js
deleted file mode 100644
index 2b253fce2c..0000000000
--- a/server/services/zigbee2mqtt/model/Belkin.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Belkin managed models.
- */
-const Belkin = {
- brand: 'Belkin',
- models: {
- F7C033: [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Belkin,
-};
diff --git a/server/services/zigbee2mqtt/model/Bitron.js b/server/services/zigbee2mqtt/model/Bitron.js
deleted file mode 100644
index c11f906f00..0000000000
--- a/server/services/zigbee2mqtt/model/Bitron.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Bitron managed models.
- */
-const Bitron = {
- brand: 'Bitron',
- models: {
- 'AV2010/34': [features.switch_sensor],
- 'AV2010/22': [features.motion],
- 'AV2010/25': [features.switch, features.power],
- 'AV2010/32': [features.switch_sensor], // features.heating],
- },
-};
-
-module.exports = {
- Bitron,
-};
diff --git a/server/services/zigbee2mqtt/model/Blaupunkt.js b/server/services/zigbee2mqtt/model/Blaupunkt.js
deleted file mode 100644
index c007b762fa..0000000000
--- a/server/services/zigbee2mqtt/model/Blaupunkt.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Blaupunkt managed models.
- */
-const Blaupunkt = {
- brand: 'Blaupunkt',
- models: {
- 'SCM-S1': [features.door], // curtain / shutter
- },
-};
-
-module.exports = {
- Blaupunkt,
-};
diff --git a/server/services/zigbee2mqtt/model/Bosch.js b/server/services/zigbee2mqtt/model/Bosch.js
deleted file mode 100644
index c9139ad90e..0000000000
--- a/server/services/zigbee2mqtt/model/Bosch.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Bosch managed models.
- */
-const Bosch = {
- brand: 'Bosch',
- models: {
- 'RADON TriTech ZB': [features.temperature, features.motion],
- 'ISW-ZPR1-WP13': [features.temperature, features.motion],
- },
-};
-
-module.exports = {
- Bosch,
-};
diff --git a/server/services/zigbee2mqtt/model/Calex.js b/server/services/zigbee2mqtt/model/Calex.js
deleted file mode 100644
index 5a1c2d1f1f..0000000000
--- a/server/services/zigbee2mqtt/model/Calex.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Calex managed models.
- */
-const Calex = {
- brand: 'Calex',
- models: {
- '421786': [features.light, features.brightness],
- '421792': [features.light, features.brightness, features.color_temperature, features.color],
- },
-};
-
-module.exports = {
- Calex,
-};
diff --git a/server/services/zigbee2mqtt/model/Centralite.js b/server/services/zigbee2mqtt/model/Centralite.js
deleted file mode 100644
index 12d03fcfd9..0000000000
--- a/server/services/zigbee2mqtt/model/Centralite.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Centralite managed models.
- */
-const Centralite = {
- brand: 'Centralite',
- models: {
- '4256251-RZHAC': [features.switch, features.power],
- },
-};
-
-module.exports = {
- Centralite,
-};
diff --git a/server/services/zigbee2mqtt/model/Climax.js b/server/services/zigbee2mqtt/model/Climax.js
deleted file mode 100644
index 72fb32f4c6..0000000000
--- a/server/services/zigbee2mqtt/model/Climax.js
+++ /dev/null
@@ -1,17 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Climax managed models.
- */
-const Climax = {
- brand: 'Climax',
- models: {
- 'PSS-23ZBS': [features.switch],
- 'SCM-5ZBS': [features.door], // curtain / shutter
- 'PSM-29ZBSR': [features.switch],
- },
-};
-
-module.exports = {
- Climax,
-};
diff --git a/server/services/zigbee2mqtt/model/CommercialElectric.js b/server/services/zigbee2mqtt/model/CommercialElectric.js
deleted file mode 100644
index 2ee9878d72..0000000000
--- a/server/services/zigbee2mqtt/model/CommercialElectric.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Commercial Electric managed models.
- */
-const CommercialElectric = {
- brand: 'Commercial Electric',
- models: {
- '53170161': [features.light, features.brightness, features.color_temperature],
- },
-};
-
-module.exports = {
- CommercialElectric,
-};
diff --git a/server/services/zigbee2mqtt/model/Danalock.js b/server/services/zigbee2mqtt/model/Danalock.js
deleted file mode 100644
index b7a820b9c7..0000000000
--- a/server/services/zigbee2mqtt/model/Danalock.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Danalock managed models.
- */
-const Danalock = {
- brand: 'Danalock',
- models: {
- 'V3-BTZB': [features.door],
- },
-};
-
-module.exports = {
- Danalock,
-};
diff --git a/server/services/zigbee2mqtt/model/DresdenElektronik.js b/server/services/zigbee2mqtt/model/DresdenElektronik.js
deleted file mode 100644
index 6db98273b4..0000000000
--- a/server/services/zigbee2mqtt/model/DresdenElektronik.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Dresden Elektronik managed models.
- */
-const DresdenElektronik = {
- brand: 'Dresden Elektronik',
- models: {
- Mega23M12: [features.light, features.brightness, features.color_temperature, features.color],
- 'XVV-Mega23M12': [features.light, features.brightness, features.color_temperature],
- },
-};
-
-module.exports = {
- DresdenElektronik,
-};
diff --git a/server/services/zigbee2mqtt/model/EDP.js b/server/services/zigbee2mqtt/model/EDP.js
deleted file mode 100644
index 09c52c2026..0000000000
--- a/server/services/zigbee2mqtt/model/EDP.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * EDP managed models.
- */
-const EDP = {
- brand: 'EDP',
- models: {
- 'PLUG EDP RE:DY': [features.switch, features.power],
- 'SWITCH EDP RE:DY': [features.switch],
- },
-};
-
-module.exports = {
- EDP,
-};
diff --git a/server/services/zigbee2mqtt/model/ELKO.js b/server/services/zigbee2mqtt/model/ELKO.js
deleted file mode 100644
index 1253354f19..0000000000
--- a/server/services/zigbee2mqtt/model/ELKO.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * ELKO managed models.
- */
-const ELKO = {
- brand: 'ELKO',
- models: {
- '316GLEDRF': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- ELKO,
-};
diff --git a/server/services/zigbee2mqtt/model/EcoSmart.js b/server/services/zigbee2mqtt/model/EcoSmart.js
deleted file mode 100644
index 8a46c86477..0000000000
--- a/server/services/zigbee2mqtt/model/EcoSmart.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * EcoSmart managed models.
- */
-const EcoSmart = {
- brand: 'EcoSmart',
- models: {
- D1821: [features.light, features.brightness, features.color_temperature, features.color],
- D1531: [features.light, features.brightness],
- D1532: [features.light, features.brightness],
- D1542: [features.light, features.brightness, features.color_temperature],
- },
-};
-
-module.exports = {
- EcoSmart,
-};
diff --git a/server/services/zigbee2mqtt/model/Eurotronic.js b/server/services/zigbee2mqtt/model/Eurotronic.js
deleted file mode 100644
index 176c5c4802..0000000000
--- a/server/services/zigbee2mqtt/model/Eurotronic.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Eurotronic managed models.
- */
-const Eurotronic = {
- brand: 'Eurotronic',
- models: {
- SPZB0001: [features.temperature], // features.heating],
- },
-};
-
-module.exports = {
- Eurotronic,
-};
diff --git a/server/services/zigbee2mqtt/model/GE.js b/server/services/zigbee2mqtt/model/GE.js
deleted file mode 100644
index 9a70d6fae0..0000000000
--- a/server/services/zigbee2mqtt/model/GE.js
+++ /dev/null
@@ -1,19 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * GE managed models.
- */
-const GE = {
- brand: 'GE',
- models: {
- '22670': [features.light, features.brightness],
- '45852GE': [features.light, features.brightness],
- '45853GE': [features.switch, features.power],
- '45856GE': [features.switch],
- '45857GE': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- GE,
-};
diff --git a/server/services/zigbee2mqtt/model/GMYSmartBulb.js b/server/services/zigbee2mqtt/model/GMYSmartBulb.js
deleted file mode 100644
index b03b809c12..0000000000
--- a/server/services/zigbee2mqtt/model/GMYSmartBulb.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * GMY Smart Bulb managed models.
- */
-const GMYSmartBulb = {
- brand: 'GMY Smart Bulb',
- models: {
- B07KG5KF5R: [features.light, features.brightness, features.color_temperature],
- },
-};
-
-module.exports = {
- GMYSmartBulb,
-};
diff --git a/server/services/zigbee2mqtt/model/Gira.js b/server/services/zigbee2mqtt/model/Gira.js
deleted file mode 100644
index c67ae10670..0000000000
--- a/server/services/zigbee2mqtt/model/Gira.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Gira managed models.
- */
-const Gira = {
- brand: 'Gira',
- models: {
- '2430-100': [features.switch_sensor],
- },
-};
-
-module.exports = {
- Gira,
-};
diff --git a/server/services/zigbee2mqtt/model/Gledopto.js b/server/services/zigbee2mqtt/model/Gledopto.js
deleted file mode 100644
index a2b46a7748..0000000000
--- a/server/services/zigbee2mqtt/model/Gledopto.js
+++ /dev/null
@@ -1,26 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Gledopto managed models.
- */
-const Gledopto = {
- brand: 'Gledopto',
- models: {
- 'GL-C-008': [features.light, features.brightness, features.color_temperature, features.color],
- 'GL-S-004Z': [features.light, features.brightness, features.color_temperature],
- 'GL-C-006/GL-C-009': [features.light, features.brightness, features.color_temperature],
- 'GL-S-007Z': [features.light, features.brightness, features.color_temperature],
- 'GL-B-001Z': [features.light, features.brightness, features.color_temperature],
- 'GL-G-001Z': [features.light, features.brightness, features.color_temperature, features.color],
- 'GL-B-007Z': [features.light, features.brightness, features.color_temperature, features.color],
- 'GL-B-008Z': [features.light, features.brightness, features.color_temperature, features.color],
- 'GL-D-003Z': [features.light, features.brightness, features.color_temperature, features.color],
- 'GL-S-003Z': [features.light, features.brightness, features.color_temperature, features.color],
- 'GD-CZ-006': [features.light, features.brightness],
- 'GL-FL-004TZ': [features.light, features.brightness, features.color_temperature, features.color],
- },
-};
-
-module.exports = {
- Gledopto,
-};
diff --git a/server/services/zigbee2mqtt/model/HEIMAN.js b/server/services/zigbee2mqtt/model/HEIMAN.js
deleted file mode 100644
index 544dfdf96b..0000000000
--- a/server/services/zigbee2mqtt/model/HEIMAN.js
+++ /dev/null
@@ -1,27 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * HEIMAN managed models.
- */
-const HEIMAN = {
- brand: 'HEIMAN',
- models: {
- 'HS1CA-M': [features.smoke],
- HS3MS: [features.motion],
- HS2SK: [features.switch, features.power],
- HS1SA: [features.smoke],
- HS3SA: [features.smoke],
- HS3CG: [features.smoke],
- 'HS1DS/HS3DS': [features.door],
- 'HEIMAN-M1': [features.door],
- 'HS1DS-E': [features.door],
- 'HS1WL/HS3WL': [features.water],
- 'HS1-WL-E': [features.water],
- 'HS1RC-M': [features.switch_sensor],
- 'HS1CA-E': [features.smoke],
- },
-};
-
-module.exports = {
- HEIMAN,
-};
diff --git a/server/services/zigbee2mqtt/model/HamptonBay.js b/server/services/zigbee2mqtt/model/HamptonBay.js
deleted file mode 100644
index 97a53a86e5..0000000000
--- a/server/services/zigbee2mqtt/model/HamptonBay.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Hampton Bay managed models.
- */
-const HamptonBay = {
- brand: 'Hampton Bay',
- models: {
- '99432': [features.switch_sensor],
- },
-};
-
-module.exports = {
- HamptonBay,
-};
diff --git a/server/services/zigbee2mqtt/model/Hive.js b/server/services/zigbee2mqtt/model/Hive.js
deleted file mode 100644
index a3a7810579..0000000000
--- a/server/services/zigbee2mqtt/model/Hive.js
+++ /dev/null
@@ -1,19 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Hive managed models.
- */
-const Hive = {
- brand: 'Hive',
- models: {
- HALIGHTDIMWWE27: [features.light, features.brightness],
- HALIGHTDIMWWB22: [features.light, features.brightness],
- '1613V': [features.switch, features.power],
- 'HV-GSCXZB269': [features.light, features.brightness, features.color_temperature],
- 'HV-GSCXZB279_HV-GSCXZB229': [features.light, features.brightness, features.color_temperature],
- },
-};
-
-module.exports = {
- Hive,
-};
diff --git a/server/services/zigbee2mqtt/model/Honyar.js b/server/services/zigbee2mqtt/model/Honyar.js
deleted file mode 100644
index ca031e265a..0000000000
--- a/server/services/zigbee2mqtt/model/Honyar.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Honyar managed models.
- */
-const Honyar = {
- brand: 'Honyar',
- models: {
- U86K31ND6: [features.switch],
- },
-};
-
-module.exports = {
- Honyar,
-};
diff --git a/server/services/zigbee2mqtt/model/IKEA.js b/server/services/zigbee2mqtt/model/IKEA.js
deleted file mode 100644
index a152dcb20a..0000000000
--- a/server/services/zigbee2mqtt/model/IKEA.js
+++ /dev/null
@@ -1,43 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * IKEA managed models.
- */
-const IKEA = {
- brand: 'IKEA',
- models: {
- LED1545G12: [features.light, features.brightness, features.color_temperature],
- LED1546G12: [features.light, features.brightness, features.color_temperature],
- LED1623G12: [features.light, features.brightness],
- LED1537R6: [features.light, features.brightness, features.color_temperature],
- LED1650R5: [features.light, features.brightness],
- LED1536G5: [features.light, features.brightness, features.color_temperature],
- LED1733G7: [features.light, features.brightness, features.color_temperature],
- LED1622G12: [features.light, features.brightness],
- LED1624G9: [features.light, features.brightness, features.color],
- LED1649C5: [features.light, features.brightness],
- LED1934G3: [features.light, features.brightness],
- LED1732G11: [features.light, features.brightness, features.color_temperature],
- LED1924G9: [features.light, features.brightness, features.color_temperature, features.color],
- 'ICTC-G-1': [features.brightness, features.switch_sensor],
- 'ICPSHC24-10EU-IL-1': [features.light, features.brightness],
- 'ICPSHC24-30EU-IL-1': [features.light, features.brightness],
- L1527: [features.light, features.brightness, features.color_temperature],
- L1529: [features.light, features.brightness, features.color_temperature],
- L1528: [features.light, features.brightness, features.color_temperature],
- L1531: [features.light, features.brightness, features.color_temperature],
- 'E1603/E1702': [features.switch],
- 'E1524/E1810': [features.switch_sensor],
- E1743: [features.button],
- 'E1525/E1745': [features.motion],
- 'E1603/E1702/E1708': [features.switch],
- // E1746: [], // Signal repeater
- 'E2001/E2002': [features.button],
- LED1836G9: [features.light, features.brightness],
- LED1837R5: [features.light],
- },
-};
-
-module.exports = {
- IKEA,
-};
diff --git a/server/services/zigbee2mqtt/model/Iluminize.js b/server/services/zigbee2mqtt/model/Iluminize.js
deleted file mode 100644
index eb46c1aac3..0000000000
--- a/server/services/zigbee2mqtt/model/Iluminize.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Iluminize managed models.
- */
-const Iluminize = {
- brand: 'Iluminize',
- models: {
- '511.10': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Iluminize,
-};
diff --git a/server/services/zigbee2mqtt/model/Immax.js b/server/services/zigbee2mqtt/model/Immax.js
deleted file mode 100644
index 43930a74d0..0000000000
--- a/server/services/zigbee2mqtt/model/Immax.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Immax managed models.
- */
-const Immax = {
- brand: 'Immax',
- models: {
- 'IM-Z3.0-DIM': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Immax,
-};
diff --git a/server/services/zigbee2mqtt/model/Innr.js b/server/services/zigbee2mqtt/model/Innr.js
deleted file mode 100644
index 2971643d24..0000000000
--- a/server/services/zigbee2mqtt/model/Innr.js
+++ /dev/null
@@ -1,42 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Innr managed models.
- */
-const Innr = {
- brand: 'Innr',
- models: {
- 'RB 185 C': [features.light, features.brightness, features.color_temperature, features.color],
- 'BY 185 C': [features.light, features.brightness, features.color_temperature, features.color],
- 'RB 250 C': [features.light, features.brightness, features.color_temperature, features.color],
- 'RB 265': [features.light, features.brightness],
- 'RB 278 T': [features.light, features.brightness],
- 'RB 285 C': [features.light, features.brightness, features.color_temperature, features.color],
- 'BY 285 C': [features.light, features.brightness, features.color_temperature, features.color],
- 'RB 165': [features.light, features.brightness],
- 'RB 175 W': [features.light, features.brightness],
- 'RB 178 T': [features.light, features.brightness, features.color_temperature],
- 'RS 122': [features.light, features.brightness],
- 'RS 125': [features.light, features.brightness],
- 'RS 225': [features.light, features.brightness],
- 'RS 128 T': [features.light, features.brightness, features.color_temperature],
- 'RS 228 T': [features.light, features.brightness, features.color_temperature],
- 'RB 145': [features.light, features.brightness],
- 'RB 245': [features.light, features.brightness],
- 'RB 248 T': [features.light, features.brightness, features.color_temperature],
- 'BY 165': [features.light, features.brightness],
- 'PL 110': [features.light, features.brightness],
- 'ST 110': [features.light, features.brightness],
- 'UC 110': [features.light, features.brightness],
- 'DL 110 N': [features.light, features.brightness],
- 'DL 110 W': [features.light, features.brightness],
- 'SL 110 N': [features.light, features.brightness],
- 'SL 110 M': [features.light, features.brightness],
- 'SL 110 W': [features.light, features.brightness],
- 'SP 120': [features.switch, features.power],
- },
-};
-
-module.exports = {
- Innr,
-};
diff --git a/server/services/zigbee2mqtt/model/Iris.js b/server/services/zigbee2mqtt/model/Iris.js
deleted file mode 100644
index b2d92496d6..0000000000
--- a/server/services/zigbee2mqtt/model/Iris.js
+++ /dev/null
@@ -1,17 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Iris managed models.
- */
-const Iris = {
- brand: 'Iris',
- models: {
- '3210-L': [features.switch],
- '3326-L': [features.temperature, features.motion],
- '3320-L': [features.door],
- },
-};
-
-module.exports = {
- Iris,
-};
diff --git a/server/services/zigbee2mqtt/model/JIAWEN.js b/server/services/zigbee2mqtt/model/JIAWEN.js
deleted file mode 100644
index 684e31de96..0000000000
--- a/server/services/zigbee2mqtt/model/JIAWEN.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * JIAWEN managed models.
- */
-const JIAWEN = {
- brand: 'JIAWEN',
- models: {
- K2RGBW01: [features.light, features.brightness, features.color_temperature, features.color],
- },
-};
-
-module.exports = {
- JIAWEN,
-};
diff --git a/server/services/zigbee2mqtt/model/KeenHome.js b/server/services/zigbee2mqtt/model/KeenHome.js
deleted file mode 100644
index 1871ea801f..0000000000
--- a/server/services/zigbee2mqtt/model/KeenHome.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Keen Home managed models.
- */
-const KeenHome = {
- brand: 'Keen Home',
- models: {
- SV01: [features.door, features.temperature, features.pressure],
- SV02: [features.door, features.temperature, features.pressure],
- },
-};
-
-module.exports = {
- KeenHome,
-};
diff --git a/server/services/zigbee2mqtt/model/KsentryElectronics.js b/server/services/zigbee2mqtt/model/KsentryElectronics.js
deleted file mode 100644
index a4222f3f6b..0000000000
--- a/server/services/zigbee2mqtt/model/KsentryElectronics.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Ksentry Electronics managed models.
- */
-const KsentryElectronics = {
- brand: 'Ksentry Electronics',
- models: {
- 'KS-SM001': [features.switch],
- },
-};
-
-module.exports = {
- KsentryElectronics,
-};
diff --git a/server/services/zigbee2mqtt/model/Leedarson.js b/server/services/zigbee2mqtt/model/Leedarson.js
deleted file mode 100644
index 8f736fdf9c..0000000000
--- a/server/services/zigbee2mqtt/model/Leedarson.js
+++ /dev/null
@@ -1,17 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Leedarson managed models.
- */
-const Leedarson = {
- brand: 'Leedarson',
- models: {
- ZM350STW1TCF: [features.light, features.brightness, features.color_temperature],
- M350STW1: [features.light, features.brightness],
- 'A806S-Q1R': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Leedarson,
-};
diff --git a/server/services/zigbee2mqtt/model/Lidl.js b/server/services/zigbee2mqtt/model/Lidl.js
deleted file mode 100644
index 5422bbc598..0000000000
--- a/server/services/zigbee2mqtt/model/Lidl.js
+++ /dev/null
@@ -1,25 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Lidl managed models.
- */
-const Lidl = {
- brand: 'Lidl',
- models: {
- HG06337: [features.switch],
- HG06104A: [features.light, features.brightness, features.color_temperature, features.color],
- HG06492C: [features.light, features.brightness, features.color_temperature],
- HG06492B: [features.light, features.brightness, features.color_temperature],
- HG06492A: [features.light, features.brightness, features.color_temperature],
- HG06106C: [features.light, features.brightness, features.color_temperature, features.color],
- HG06106A: [features.light, features.brightness, features.color_temperature, features.color],
- HG06106B: [features.light, features.brightness, features.color_temperature, features.color],
- '14147206L': [features.light, features.brightness, features.color_temperature, features.color],
- '14148906L': [features.light, features.brightness, features.color_temperature, features.color],
- '14149505L/14149506L': [features.light, features.brightness, features.color_temperature, features.color],
- },
-};
-
-module.exports = {
- Lidl,
-};
diff --git a/server/services/zigbee2mqtt/model/LivingWise.js b/server/services/zigbee2mqtt/model/LivingWise.js
deleted file mode 100644
index 3711faa0ff..0000000000
--- a/server/services/zigbee2mqtt/model/LivingWise.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * LivingWise managed models.
- */
-const LivingWise = {
- brand: 'LivingWise',
- models: {
- 'LVS-ZB500D': [features.light, features.brightness],
- 'LVS-SM10ZW': [features.door],
- },
-};
-
-module.exports = {
- LivingWise,
-};
diff --git a/server/services/zigbee2mqtt/model/Livolo.js b/server/services/zigbee2mqtt/model/Livolo.js
deleted file mode 100644
index ea583aeaa3..0000000000
--- a/server/services/zigbee2mqtt/model/Livolo.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Livolo managed models.
- */
-const Livolo = {
- brand: 'Livolo',
- models: {
- TI0001: [features.switch_sensor],
- },
-};
-
-module.exports = {
- Livolo,
-};
diff --git a/server/services/zigbee2mqtt/model/Lonsonho.js b/server/services/zigbee2mqtt/model/Lonsonho.js
deleted file mode 100644
index f20c3d7852..0000000000
--- a/server/services/zigbee2mqtt/model/Lonsonho.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Leedarson managed models.
- */
-const Lonsonho = {
- brand: 'Lonsonho',
- models: {
- 'QS-Zigbee-D02-TRIAC-L': [features.light, features.brightness],
- 'QS-Zigbee-D02-TRIAC-LN': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Lonsonho,
-};
diff --git a/server/services/zigbee2mqtt/model/Lupus.js b/server/services/zigbee2mqtt/model/Lupus.js
deleted file mode 100644
index 8b87c0df0a..0000000000
--- a/server/services/zigbee2mqtt/model/Lupus.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Lupus managed models.
- */
-const Lupus = {
- brand: 'Lupus',
- models: {
- '12031': [features.switch], // curtain / shutter
- '12050': [features.switch, features.power],
- },
-};
-
-module.exports = {
- Lupus,
-};
diff --git a/server/services/zigbee2mqtt/model/Meazon.js b/server/services/zigbee2mqtt/model/Meazon.js
deleted file mode 100644
index 72e4553854..0000000000
--- a/server/services/zigbee2mqtt/model/Meazon.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Meazon managed models.
- */
-const Meazon = {
- brand: 'Meazon',
- models: {
- MEAZON_BIZY_PLUG: [features.switch, features.power, features.temperature],
- MEAZON_DINRAIL: [features.switch, features.power, features.temperature],
- },
-};
-
-module.exports = {
- Meazon,
-};
diff --git a/server/services/zigbee2mqtt/model/MullerLicht.js b/server/services/zigbee2mqtt/model/MullerLicht.js
deleted file mode 100644
index a413c28ec8..0000000000
--- a/server/services/zigbee2mqtt/model/MullerLicht.js
+++ /dev/null
@@ -1,17 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Müller Licht managed models.
- */
-const MullerLicht = {
- brand: 'Müller Licht',
- models: {
- '404000/404005/404012': [features.light, features.brightness, features.color_temperature, features.color],
- '404006/404008/404004': [features.light, features.brightness, features.color_temperature],
- 'MLI-404011': [features.switch_sensor],
- },
-};
-
-module.exports = {
- MullerLicht,
-};
diff --git a/server/services/zigbee2mqtt/model/NET2GRID.js b/server/services/zigbee2mqtt/model/NET2GRID.js
deleted file mode 100644
index 5e8c8d30d0..0000000000
--- a/server/services/zigbee2mqtt/model/NET2GRID.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * NET2GRID managed models.
- */
-const NET2GRID = {
- brand: 'NET2GRID',
- models: {
- 'N2G-SP': [features.switch, features.power],
- },
-};
-
-module.exports = {
- NET2GRID,
-};
diff --git a/server/services/zigbee2mqtt/model/Nanoleaf.js b/server/services/zigbee2mqtt/model/Nanoleaf.js
deleted file mode 100644
index 9f0e01956a..0000000000
--- a/server/services/zigbee2mqtt/model/Nanoleaf.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Nanoleaf managed models.
- */
-const Nanoleaf = {
- brand: 'Nanoleaf',
- models: {
- 'NL08-0800': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Nanoleaf,
-};
diff --git a/server/services/zigbee2mqtt/model/Netvox.js b/server/services/zigbee2mqtt/model/Netvox.js
deleted file mode 100644
index aeb68b5707..0000000000
--- a/server/services/zigbee2mqtt/model/Netvox.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Netvox managed models.
- */
-const Netvox = {
- brand: 'Netvox',
- models: {
- Z809A: [features.switch, features.power],
- },
-};
-
-module.exports = {
- Netvox,
-};
diff --git a/server/services/zigbee2mqtt/model/NinjaBlocks.js b/server/services/zigbee2mqtt/model/NinjaBlocks.js
deleted file mode 100644
index b877835972..0000000000
--- a/server/services/zigbee2mqtt/model/NinjaBlocks.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Ninja Blocks managed models.
- */
-const NinjaBlocks = {
- brand: 'Ninja Blocks',
- models: {
- Z809AF: [features.switch, features.power],
- },
-};
-
-module.exports = {
- NinjaBlocks,
-};
diff --git a/server/services/zigbee2mqtt/model/Nue_3A.js b/server/services/zigbee2mqtt/model/Nue_3A.js
deleted file mode 100644
index ce938befd1..0000000000
--- a/server/services/zigbee2mqtt/model/Nue_3A.js
+++ /dev/null
@@ -1,31 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Nue / 3A managed models.
- */
-const Nue3A = {
- brand: 'Nue / 3A',
- models: {
- 'HGZB-1S': [features.switch, features.switch_sensor],
- 'HGZB-02S': [features.switch, features.switch_sensor],
- 'HGZB-045': [features.switch, features.switch_sensor],
- 'LXZB-02A': [features.light, features.brightness],
- 'HGZB-43': [features.switch],
- 'HGZB-043': [features.switch],
- 'HGZB-04D': [features.light, features.brightness],
- 'HGZB-042': [features.switch],
- 'HGZB-42': [features.switch],
- 'HGZB-01A/02A': [features.switch],
- 'HGZB-41': [features.switch],
- 'MG-AUWS01': [features.switch],
- 'HGZB-01A': [features.light, features.brightness],
- 'XY12S-15': [features.light, features.brightness, features.color_temperature, features.color],
- 'HGZB-02A': [features.light, features.brightness],
- 'HGZB-42-UK / HGZB-41': [features.switch],
- 'HGZB-06A': [features.light, features.brightness, features.color_temperature, features.color],
- },
-};
-
-module.exports = {
- Nue3A,
-};
diff --git a/server/services/zigbee2mqtt/model/Nyce.js b/server/services/zigbee2mqtt/model/Nyce.js
deleted file mode 100644
index 1a55cb52de..0000000000
--- a/server/services/zigbee2mqtt/model/Nyce.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Nyce managed models.
- */
-const Nyce = {
- brand: 'Nyce',
- models: {
- 'NCZ-3011-HA': [features.temperature, features.motion, features.humidity],
- 'NCZ-3043-HA': [features.temperature, features.motion],
- 'NCZ-3041-HA': [features.temperature, features.motion],
- 'NCZ-3045-HA': [features.temperature, features.motion],
- },
-};
-
-module.exports = {
- Nyce,
-};
diff --git a/server/services/zigbee2mqtt/model/ORVIBO.js b/server/services/zigbee2mqtt/model/ORVIBO.js
deleted file mode 100644
index 840b0e29ad..0000000000
--- a/server/services/zigbee2mqtt/model/ORVIBO.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * ORVIBO managed models.
- */
-const ORVIBO = {
- brand: 'ORVIBO',
- models: {
- SN10ZW: [features.motion],
- },
-};
-
-module.exports = {
- ORVIBO,
-};
diff --git a/server/services/zigbee2mqtt/model/OSRAM.js b/server/services/zigbee2mqtt/model/OSRAM.js
deleted file mode 100644
index c843ec42cd..0000000000
--- a/server/services/zigbee2mqtt/model/OSRAM.js
+++ /dev/null
@@ -1,37 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * OSRAM managed models.
- */
-const OSRAM = {
- brand: 'OSRAM',
- models: {
- '4058075816718': [features.light, features.brightness, features.color_temperature, features.color],
- AA69697: [features.light, features.brightness, features.color_temperature, features.color],
- AC03645: [features.light, features.brightness, features.color_temperature, features.color],
- AC03642: [features.light, features.brightness, features.color_temperature],
- AC03647: [features.light, features.brightness, features.color_temperature, features.color],
- AA70155: [features.light, features.brightness, features.color_temperature],
- AA68199: [features.light, features.brightness, features.color_temperature],
- AB32840: [features.light, features.brightness, features.color_temperature],
- '4058075816794': [features.light, features.brightness, features.color_temperature],
- AC03641: [features.light, features.brightness],
- '4052899926158': [features.light, features.brightness],
- AB401130055: [features.light, features.brightness, features.color_temperature],
- AB3257001NJ: [features.switch],
- '4052899926110': [features.light, features.brightness, features.color_temperature, features.color],
- '4058075036185': [features.light, features.brightness, features.color_temperature, features.color],
- '4058075036147': [features.light, features.brightness, features.color_temperature, features.color],
- AC0363900NJ: [features.light, features.brightness, features.color_temperature, features.color],
- AB35996: [features.light, features.brightness, features.color_temperature, features.color],
- AC08562: [features.light, features.brightness],
- AC01353010G: [features.temperature, features.motion],
- AC03648: [features.light, features.brightness, features.color_temperature],
- AC0251100NJ: [features.switch_sensor],
- 'ST8AU-CON': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- OSRAM,
-};
diff --git a/server/services/zigbee2mqtt/model/Oujiabao.js b/server/services/zigbee2mqtt/model/Oujiabao.js
deleted file mode 100644
index 5a39c2f9f0..0000000000
--- a/server/services/zigbee2mqtt/model/Oujiabao.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Oujiabao managed models.
- */
-const Oujiabao = {
- brand: 'Oujiabao',
- models: {
- 'CR701-YZ': [features.smoke, features.smoke],
- },
-};
-
-module.exports = {
- Oujiabao,
-};
diff --git a/server/services/zigbee2mqtt/model/PaulNeuhaus.js b/server/services/zigbee2mqtt/model/PaulNeuhaus.js
deleted file mode 100644
index 2320f8a3ee..0000000000
--- a/server/services/zigbee2mqtt/model/PaulNeuhaus.js
+++ /dev/null
@@ -1,17 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Paul Neuhaus managed models.
- */
-const PaulNeuhaus = {
- brand: 'Paul Neuhaus',
- models: {
- '100.424.11': [features.light, features.brightness, features.color_temperature],
- '100.110.39': [features.light, features.brightness, features.color_temperature, features.color],
- '100.425.90': [features.switch],
- },
-};
-
-module.exports = {
- PaulNeuhaus,
-};
diff --git a/server/services/zigbee2mqtt/model/Paulmann.js b/server/services/zigbee2mqtt/model/Paulmann.js
deleted file mode 100644
index bf03bf8a7a..0000000000
--- a/server/services/zigbee2mqtt/model/Paulmann.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Paulmann managed models.
- */
-const Paulmann = {
- brand: 'Paulmann',
- models: {
- '50043': [features.switch],
- '50045': [features.light, features.brightness],
- '50049': [features.light, features.brightness, features.color_temperature, features.color],
- '50064': [features.light, features.brightness, features.color_temperature],
- },
-};
-
-module.exports = {
- Paulmann,
-};
diff --git a/server/services/zigbee2mqtt/model/Philips.js b/server/services/zigbee2mqtt/model/Philips.js
deleted file mode 100644
index ed0127c652..0000000000
--- a/server/services/zigbee2mqtt/model/Philips.js
+++ /dev/null
@@ -1,51 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Philips managed models.
- */
-const Philips = {
- brand: 'Philips',
- models: {
- '7299760PH': [features.light, features.brightness, features.color],
- '7146060PH': [features.light, features.brightness, features.color_temperature, features.color],
- '4090531P7': [features.light, features.brightness, features.color_temperature, features.color],
- '433714': [features.light, features.brightness],
- '8718696449691': [features.light, features.brightness],
- '9290018195': [features.light, features.brightness],
- '7299355PH': [features.light, features.brightness, features.color],
- '915005106701': [features.light, features.brightness, features.color_temperature, features.color],
- '9290012573A': [features.light, features.brightness, features.color_temperature, features.color],
- '9290002579A': [features.light, features.brightness, features.color_temperature, features.color],
- '8718696485880': [features.light, features.brightness, features.color_temperature, features.color],
- '915005733701': [features.light, features.brightness, features.color_temperature, features.color],
- '464800': [features.light, features.brightness, features.color_temperature],
- '8718696695203': [features.light, features.brightness, features.color_temperature],
- '8718696598283': [features.light, features.brightness, features.color_temperature],
- '9290011998B': [features.light, features.brightness, features.color_temperature],
- '8718696548738': [features.light, features.brightness, features.color_temperature],
- '4090130P7': [features.light, features.brightness, features.color_temperature, features.color],
- '3261030P7': [features.light, features.brightness, features.color_temperature],
- '3261331P7': [features.light, features.brightness, features.color_temperature],
- '4096730U7': [features.light, features.brightness, features.color_temperature],
- '3216131P5': [features.light, features.brightness, features.color_temperature],
- '3216331P5': [features.light, features.brightness, features.color_temperature],
- '3216431P5': [features.light, features.brightness, features.color_temperature],
- '4033930P7': [features.light, features.brightness, features.color_temperature],
- '9290011370B': [features.light, features.brightness],
- '046677476816': [features.light, features.brightness],
- '7199960PH': [features.light, features.brightness, features.color],
- '324131092621': [features.switch_sensor],
- '9290012607': [features.temperature, features.motion, features.illuminance],
- '9290019758': [features.temperature, features.motion, features.illuminance],
- '7099860PH': [features.light, features.brightness, features.color],
- '3216231P5': [features.light, features.brightness, features.color_temperature],
- '8718696170625': [features.light, features.brightness],
- '8718699673147': [features.light, features.brightness],
- '9290022166': [features.light, features.brightness, features.color_temperature], // color xy
- '929002241201': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Philips,
-};
diff --git a/server/services/zigbee2mqtt/model/RGBGenie.js b/server/services/zigbee2mqtt/model/RGBGenie.js
deleted file mode 100644
index 77418405b1..0000000000
--- a/server/services/zigbee2mqtt/model/RGBGenie.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * RGBGenie managed models.
- */
-const RGBGenie = {
- brand: 'RGB Genie',
- models: {
- 'ZGRC-KEY-013': [features.switch_sensor],
- },
-};
-
-module.exports = {
- RGBGenie,
-};
diff --git a/server/services/zigbee2mqtt/model/ROBB.js b/server/services/zigbee2mqtt/model/ROBB.js
deleted file mode 100644
index 7ddc5b531f..0000000000
--- a/server/services/zigbee2mqtt/model/ROBB.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * ROBB managed models.
- */
-const ROBB = {
- brand: 'ROBB',
- models: {
- 'ROB_200-004-0': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- ROBB,
-};
diff --git a/server/services/zigbee2mqtt/model/SONOFF.js b/server/services/zigbee2mqtt/model/SONOFF.js
deleted file mode 100644
index 616448e8ae..0000000000
--- a/server/services/zigbee2mqtt/model/SONOFF.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * SONOFF managed models.
- */
-const SONOFF = {
- brand: 'SONOFF',
- models: {
- 'SNZB-01': [features.button],
- 'SNZB-02': [features.temperature, features.humidity],
- 'SNZB-03': [features.motion],
- 'SNZB-04': [features.door],
- },
-};
-
-module.exports = {
- SONOFF,
-};
diff --git a/server/services/zigbee2mqtt/model/Salus.js b/server/services/zigbee2mqtt/model/Salus.js
deleted file mode 100644
index 8584e79022..0000000000
--- a/server/services/zigbee2mqtt/model/Salus.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Salus managed models.
- */
-const Salus = {
- brand: 'Salus',
- models: {
- SP600: [features.switch, features.power],
- },
-};
-
-module.exports = {
- Salus,
-};
diff --git a/server/services/zigbee2mqtt/model/Securifi.js b/server/services/zigbee2mqtt/model/Securifi.js
deleted file mode 100644
index ad80ea8c96..0000000000
--- a/server/services/zigbee2mqtt/model/Securifi.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Securifi managed models.
- */
-const Securifi = {
- brand: 'Securifi',
- models: {
- 'PP-WHT-US': [features.switch, features.power, features.current, features.voltage],
- },
-};
-
-module.exports = {
- Securifi,
-};
diff --git a/server/services/zigbee2mqtt/model/Sengled.js b/server/services/zigbee2mqtt/model/Sengled.js
deleted file mode 100644
index 0cf92ae916..0000000000
--- a/server/services/zigbee2mqtt/model/Sengled.js
+++ /dev/null
@@ -1,21 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Sengled managed models.
- */
-const Sengled = {
- brand: 'Sengled',
- models: {
- 'E11-G13': [features.light, features.brightness],
- 'E11-G23/E11-G33': [features.light, features.brightness],
- 'Z01-CIA19NAE26': [features.light, features.brightness],
- 'Z01-A19NAE26': [features.light, features.brightness, features.color_temperature],
- 'E11-N1EA': [features.light, features.brightness, features.color_temperature, features.color],
- 'E12-N14': [features.light, features.brightness],
- E1ACA4ABE38A: [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Sengled,
-};
diff --git a/server/services/zigbee2mqtt/model/Sercomm.js b/server/services/zigbee2mqtt/model/Sercomm.js
deleted file mode 100644
index 4401b382e7..0000000000
--- a/server/services/zigbee2mqtt/model/Sercomm.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Sercomm managed models.
- */
-const Sercomm = {
- brand: 'Sercomm',
- models: {
- 'SZ-ESW01-AU': [features.switch, features.power],
- },
-};
-
-module.exports = {
- Sercomm,
-};
diff --git a/server/services/zigbee2mqtt/model/ShenzhenHoma.js b/server/services/zigbee2mqtt/model/ShenzhenHoma.js
deleted file mode 100644
index ffb9086be8..0000000000
--- a/server/services/zigbee2mqtt/model/ShenzhenHoma.js
+++ /dev/null
@@ -1,17 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Shenzhen Homa managed models.
- */
-const ShenzhenHoma = {
- brand: 'Shenzhen Homa',
- models: {
- 'HLD812-Z-SC': [features.light, features.brightness],
- 'HLC610-Z': [features.light, features.brightness],
- 'HLC821-Z-SC': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- ShenzhenHoma,
-};
diff --git a/server/services/zigbee2mqtt/model/SmartHomePty.js b/server/services/zigbee2mqtt/model/SmartHomePty.js
deleted file mode 100644
index d21d080d60..0000000000
--- a/server/services/zigbee2mqtt/model/SmartHomePty.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Smart Home Pty managed models.
- */
-const SmartHomePty = {
- brand: 'Smart Home Pty',
- models: {
- 'HGZB-07A': [features.switch, features.color_temperature],
- 'HGZB-20-DE': [features.switch],
- },
-};
-
-module.exports = {
- SmartHomePty,
-};
diff --git a/server/services/zigbee2mqtt/model/SmartThings.js b/server/services/zigbee2mqtt/model/SmartThings.js
deleted file mode 100644
index 3ac1f0e763..0000000000
--- a/server/services/zigbee2mqtt/model/SmartThings.js
+++ /dev/null
@@ -1,29 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * SmartThings managed models.
- */
-const SmartThings = {
- brand: 'SmartThings',
- models: {
- 'STSS-MULT-001': [features.door],
- 'STS-PRS-251': [features.motion],
- '3325-S': [features.temperature, features.motion],
- '3321-S': [features.temperature, features.door],
- 'IM6001-OTP05': [features.switch],
- 'IM6001-MTP01': [features.temperature, features.motion],
- 'STS-IRM-250': [features.temperature, features.motion],
- '3305-S': [features.temperature, features.motion],
- '3300-S': [features.temperature, features.door],
- 'F-MLT-US-2': [features.temperature, features.door],
- 'IM6001-MPP01': [features.temperature, features.door],
- '3310-S': [features.temperature],
- '3315-S': [features.temperature, features.water],
- '3315-G': [features.temperature, features.water],
- 'IM6001-BTP01': [features.switch_sensor, features.temperature],
- },
-};
-
-module.exports = {
- SmartThings,
-};
diff --git a/server/services/zigbee2mqtt/model/Stelpro.js b/server/services/zigbee2mqtt/model/Stelpro.js
deleted file mode 100644
index cc8de5bfcb..0000000000
--- a/server/services/zigbee2mqtt/model/Stelpro.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Stelpro managed models.
- */
-const Stelpro = {
- brand: 'Stelpro',
- models: {
- ST218: [features.temperature],
- },
-};
-
-module.exports = {
- Stelpro,
-};
diff --git a/server/services/zigbee2mqtt/model/Sunricher.js b/server/services/zigbee2mqtt/model/Sunricher.js
deleted file mode 100644
index 93cae3b753..0000000000
--- a/server/services/zigbee2mqtt/model/Sunricher.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Sunricher managed models.
- */
-const Sunricher = {
- brand: 'Sunricher',
- models: {
- 'ZG9101SAC-HP': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Sunricher,
-};
diff --git a/server/services/zigbee2mqtt/model/Swann.js b/server/services/zigbee2mqtt/model/Swann.js
deleted file mode 100644
index 9535e5f352..0000000000
--- a/server/services/zigbee2mqtt/model/Swann.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Swann managed models.
- */
-const Swann = {
- brand: 'Swann',
- models: {
- 'SWO-KEF1PA': [features.switch_sensor],
- 'SWO-WDS1PA': [features.door],
- },
-};
-
-module.exports = {
- Swann,
-};
diff --git a/server/services/zigbee2mqtt/model/Sylvania.js b/server/services/zigbee2mqtt/model/Sylvania.js
deleted file mode 100644
index 311cd44b6b..0000000000
--- a/server/services/zigbee2mqtt/model/Sylvania.js
+++ /dev/null
@@ -1,25 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Sylvania managed models.
- */
-const Sylvania = {
- brand: 'Sylvania',
- models: {
- '73742': [features.light, features.brightness, features.color_temperature],
- '73740': [features.light, features.brightness, features.color_temperature],
- '73739': [features.light, features.brightness, features.color_temperature, features.color],
- '73693': [features.light, features.brightness, features.color_temperature, features.color],
- '74283': [features.light, features.brightness],
- '74696': [features.light, features.brightness],
- '72922-A': [features.switch],
- '71831': [features.light, features.brightness, features.color_temperature],
- '74282': [features.light, features.brightness, features.color_temperature],
- LTFY004: [features.light, features.brightness, features.color],
- '74580': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- Sylvania,
-};
diff --git a/server/services/zigbee2mqtt/model/TUYATEC.js b/server/services/zigbee2mqtt/model/TUYATEC.js
deleted file mode 100644
index a11a53cb20..0000000000
--- a/server/services/zigbee2mqtt/model/TUYATEC.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * TUYATEC managed models.
- */
-const TUYATEC = {
- brand: 'TUYATEC',
- models: {
- RH3040: [features.motion],
- },
-};
-
-module.exports = {
- TUYATEC,
-};
diff --git a/server/services/zigbee2mqtt/model/ThirdReality.js b/server/services/zigbee2mqtt/model/ThirdReality.js
deleted file mode 100644
index 6757d33e8e..0000000000
--- a/server/services/zigbee2mqtt/model/ThirdReality.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Third Reality managed models.
- */
-const ThirdReality = {
- brand: 'Third Reality',
- models: {
- '3RSS008Z': [features.switch_sensor],
- },
-};
-
-module.exports = {
- ThirdReality,
-};
diff --git a/server/services/zigbee2mqtt/model/Trust.js b/server/services/zigbee2mqtt/model/Trust.js
deleted file mode 100644
index c174821116..0000000000
--- a/server/services/zigbee2mqtt/model/Trust.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Trust managed models.
- */
-const Trust = {
- brand: 'Trust',
- models: {
- 'ZYCT-202': [features.switch_sensor],
- 'ZLED-2709': [features.light, features.brightness],
- 'ZPIR-8000': [features.motion],
- 'ZCTS-808': [features.door],
- },
-};
-
-module.exports = {
- Trust,
-};
diff --git a/server/services/zigbee2mqtt/model/TuYa.js b/server/services/zigbee2mqtt/model/TuYa.js
deleted file mode 100644
index d64c32b384..0000000000
--- a/server/services/zigbee2mqtt/model/TuYa.js
+++ /dev/null
@@ -1,21 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * TuYa managed models.
- */
-const TuYa = {
- brand: 'TuYa',
- models: {
- TS0121_plug: [features.switch, features.power, features.current, features.voltage, features.energy],
- TS0201: [features.temperature, features.humidity, features.voltage],
- TS0011: [features.switch],
- TS0601_air_quality_sensor: [features.temperature, features.humidity, features.co2],
- TT001ZAV20: [features.temperature, features.humidity],
- SNTZ007: [features.door],
- TS0503B: [features.light, features.brightness, features.color],
- },
-};
-
-module.exports = {
- TuYa,
-};
diff --git a/server/services/zigbee2mqtt/model/Visonic.js b/server/services/zigbee2mqtt/model/Visonic.js
deleted file mode 100644
index c5d1b70eef..0000000000
--- a/server/services/zigbee2mqtt/model/Visonic.js
+++ /dev/null
@@ -1,16 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Visonic managed models.
- */
-const Visonic = {
- brand: 'Visonic',
- models: {
- 'MCT-350 SMA': [features.door],
- 'MCT-340 E': [features.door],
- },
-};
-
-module.exports = {
- Visonic,
-};
diff --git a/server/services/zigbee2mqtt/model/Xiaomi.js b/server/services/zigbee2mqtt/model/Xiaomi.js
deleted file mode 100644
index 2f721d9da6..0000000000
--- a/server/services/zigbee2mqtt/model/Xiaomi.js
+++ /dev/null
@@ -1,45 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Xiaomi managed models.
- */
-const Xiaomi = {
- brand: 'Xiaomi',
- models: {
- ZNLDP12LM: [features.light, features.brightness, features.color_temperature],
- WXKG01LM: [features.button],
- WXKG11LM: [features.button],
- WXKG12LM: [features.button],
- WXKG03LM_rev1: [features.button],
- WXKG03LM_rev2: [features.button],
- WXKG02LM_rev1: [features.button],
- WXKG02LM_rev2: [features.button],
- QBKG04LM: [features.switch],
- QBKG11LM: [features.switch, features.power],
- QBKG03LM: [features.switch_sensor],
- QBKG12LM: [features.switch, features.power],
- WSDCGQ01LM: [features.temperature, features.humidity],
- WSDCGQ11LM: [features.temperature, features.humidity, features.pressure],
- RTCGQ01LM: [features.motion],
- RTCGQ11LM: [features.motion, features.illuminance, features.temperature, features.voltage],
- MCCGQ01LM: [features.door],
- MCCGQ11LM: [features.door, features.temperature],
- SJCGQ11LM: [features.water],
- MFKZQ01LM: [features.button],
- ZNCZ02LM: [features.switch, features.power],
- QBCZ11LM: [features.switch, features.power],
- 'JTYJ-GD-01LM/BW': [features.smoke],
- 'JTQJ-BF-01LM/BW': [features.smoke, features.gas_density],
- A6121: [features.door],
- DJT11LM: [features.button],
- // ZNCLDJ11LM: [features.curtain]
- LLKZMK11LM: [features.switch, features.power],
- ZNMS12LM: [features.switch_sensor, features.door],
- WXKG06LM: [features.button],
- GZCGQ01LM: [features.illuminance, features.illuminance_lux],
- },
-};
-
-module.exports = {
- Xiaomi,
-};
diff --git a/server/services/zigbee2mqtt/model/Yale.js b/server/services/zigbee2mqtt/model/Yale.js
deleted file mode 100644
index e27b60edcf..0000000000
--- a/server/services/zigbee2mqtt/model/Yale.js
+++ /dev/null
@@ -1,18 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * Yale managed models.
- */
-const Yale = {
- brand: 'Yale',
- models: {
- YRD426NRSC: [features.door],
- YRD226HA2619: [features.door],
- YRD256HA20BP: [features.door],
- YMF40: [features.door],
- },
-};
-
-module.exports = {
- Yale,
-};
diff --git a/server/services/zigbee2mqtt/model/eCosy.js b/server/services/zigbee2mqtt/model/eCosy.js
deleted file mode 100644
index 4ab856efbf..0000000000
--- a/server/services/zigbee2mqtt/model/eCosy.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * eCosy managed models.
- */
-const eCosy = {
- brand: 'eCosy',
- models: {
- '1TST-EU': [features.temperature, features.motion], // heating + schedule,
- },
-};
-
-module.exports = {
- eCosy,
-};
diff --git a/server/services/zigbee2mqtt/model/iCasa.js b/server/services/zigbee2mqtt/model/iCasa.js
deleted file mode 100644
index ac52cfd3af..0000000000
--- a/server/services/zigbee2mqtt/model/iCasa.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * iCasa managed models.
- */
-const iCasa = {
- brand: 'iCasa',
- models: {
- 'ICZB-IW11D': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- iCasa,
-};
diff --git a/server/services/zigbee2mqtt/model/ilux.js b/server/services/zigbee2mqtt/model/ilux.js
deleted file mode 100644
index 8ebd330aa3..0000000000
--- a/server/services/zigbee2mqtt/model/ilux.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const { features } = require('../utils/features');
-
-/**
- * ilux managed models.
- */
-const ilux = {
- brand: 'ilux',
- models: {
- '900008-WW': [features.light, features.brightness],
- },
-};
-
-module.exports = {
- ilux,
-};
diff --git a/server/services/zigbee2mqtt/model/index.js b/server/services/zigbee2mqtt/model/index.js
deleted file mode 100644
index 1ec3392fa1..0000000000
--- a/server/services/zigbee2mqtt/model/index.js
+++ /dev/null
@@ -1,102 +0,0 @@
-const models = [];
-models.push(require('./AduroSmart').AduroSmart);
-models.push(require('./Airam').Airam);
-models.push(require('./Anchor').Anchor);
-models.push(require('./Belkin').Belkin);
-models.push(require('./Bitron').Bitron);
-models.push(require('./Blaupunkt').Blaupunkt);
-models.push(require('./Bosch').Bosch);
-models.push(require('./Calex').Calex);
-models.push(require('./Centralite').Centralite);
-models.push(require('./Climax').Climax);
-models.push(require('./CommercialElectric').CommercialElectric);
-models.push(require('./Danalock').Danalock);
-models.push(require('./DresdenElektronik').DresdenElektronik);
-models.push(require('./EDP').EDP);
-models.push(require('./ELKO').ELKO);
-models.push(require('./EcoSmart').EcoSmart);
-models.push(require('./Eurotronic').Eurotronic);
-models.push(require('./GE').GE);
-models.push(require('./GMYSmartBulb').GMYSmartBulb);
-models.push(require('./Gira').Gira);
-models.push(require('./Gledopto').Gledopto);
-models.push(require('./HEIMAN').HEIMAN);
-models.push(require('./HamptonBay').HamptonBay);
-models.push(require('./Hive').Hive);
-models.push(require('./Honyar').Honyar);
-models.push(require('./IKEA').IKEA);
-models.push(require('./Iluminize').Iluminize);
-models.push(require('./Immax').Immax);
-models.push(require('./Innr').Innr);
-models.push(require('./Iris').Iris);
-models.push(require('./JIAWEN').JIAWEN);
-models.push(require('./KeenHome').KeenHome);
-models.push(require('./KsentryElectronics').KsentryElectronics);
-models.push(require('./Leedarson').Leedarson);
-models.push(require('./LivingWise').LivingWise);
-models.push(require('./Livolo').Livolo);
-models.push(require('./Lupus').Lupus);
-models.push(require('./Meazon').Meazon);
-models.push(require('./MullerLicht').MullerLicht);
-models.push(require('./NET2GRID').NET2GRID);
-models.push(require('./Nanoleaf').Nanoleaf);
-models.push(require('./Netvox').Netvox);
-models.push(require('./NinjaBlocks').NinjaBlocks);
-models.push(require('./Nue_3A').Nue3A);
-models.push(require('./Nyce').Nyce);
-models.push(require('./ORVIBO').ORVIBO);
-models.push(require('./OSRAM').OSRAM);
-models.push(require('./Oujiabao').Oujiabao);
-models.push(require('./PaulNeuhaus').PaulNeuhaus);
-models.push(require('./Paulmann').Paulmann);
-models.push(require('./Philips').Philips);
-models.push(require('./RGBGenie').RGBGenie);
-models.push(require('./ROBB').ROBB);
-models.push(require('./Salus').Salus);
-models.push(require('./Securifi').Securifi);
-models.push(require('./Sengled').Sengled);
-models.push(require('./Sercomm').Sercomm);
-models.push(require('./ShenzhenHoma').ShenzhenHoma);
-models.push(require('./SmartHomePty').SmartHomePty);
-models.push(require('./SmartThings').SmartThings);
-models.push(require('./SONOFF').SONOFF);
-models.push(require('./Stelpro').Stelpro);
-models.push(require('./Sunricher').Sunricher);
-models.push(require('./Swann').Swann);
-models.push(require('./Sylvania').Sylvania);
-models.push(require('./TUYATEC').TUYATEC);
-models.push(require('./ThirdReality').ThirdReality);
-models.push(require('./Trust').Trust);
-models.push(require('./Visonic').Visonic);
-models.push(require('./Xiaomi').Xiaomi);
-models.push(require('./Yale').Yale);
-models.push(require('./eCosy').eCosy);
-models.push(require('./iCasa').iCasa);
-models.push(require('./ilux').ilux);
-models.push(require('./TuYa').TuYa);
-models.push(require('./Lonsonho').Lonsonho);
-models.push(require('./Lidl').Lidl);
-models.push(require('./Adeo').Adeo);
-
-/**
- * @description Get features by model name.
- * @param {string} modelName - Model name to find.
- * @returns {Array} Related features.
- * @example
- * getFeaturesByModel('1TST-EU');
- */
-function getFeaturesByModel(modelName) {
- const model = models.find((m) => {
- return m.models[modelName];
- });
-
- if (model) {
- return model.models[modelName];
- }
-
- return [];
-}
-
-module.exports = {
- getFeaturesByModel,
-};
diff --git a/server/services/zigbee2mqtt/utils/features.js b/server/services/zigbee2mqtt/utils/features.js
deleted file mode 100644
index 884741a248..0000000000
--- a/server/services/zigbee2mqtt/utils/features.js
+++ /dev/null
@@ -1,272 +0,0 @@
-const {
- DEVICE_FEATURE_CATEGORIES,
- DEVICE_FEATURE_TYPES,
- DEVICE_FEATURE_UNITS,
-} = require('../../../../server/utils/constants');
-
-const features = {
- presence: {
- category: DEVICE_FEATURE_CATEGORIES.PRESENCE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Presence Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'presence',
- },
- motion: {
- category: DEVICE_FEATURE_CATEGORIES.MOTION_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Motion Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'occupancy',
- },
- door: {
- category: DEVICE_FEATURE_CATEGORIES.OPENING_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Opening Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'contact',
- },
- water: {
- category: DEVICE_FEATURE_CATEGORIES.LEAK_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Water Leak',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'water_leak',
- },
- smoke: {
- category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Smoke Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'smoke',
- },
- battery: {
- category: DEVICE_FEATURE_CATEGORIES.BATTERY,
- type: DEVICE_FEATURE_TYPES.SENSOR.INTEGER,
- unit: DEVICE_FEATURE_UNITS.PERCENT,
- name: 'Battery',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 100,
- zigbeeField: 'battery',
- },
- illuminance: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- unit: DEVICE_FEATURE_UNITS.LUX,
- name: 'Light Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1000,
- zigbeeField: 'illuminance',
- },
- illuminance_lux: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- unit: DEVICE_FEATURE_UNITS.LUX,
- name: 'Light Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 100000,
- zigbeeField: 'illuminance_lux',
- },
- humidity: {
- category: DEVICE_FEATURE_CATEGORIES.HUMIDITY_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- unit: DEVICE_FEATURE_UNITS.PERCENT,
- name: 'Humidity',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 100,
- zigbeeField: 'humidity',
- },
- temperature: {
- category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- unit: DEVICE_FEATURE_UNITS.CELSIUS,
- name: 'Temperature',
- read_only: true,
- has_feedback: false,
- min: -50,
- max: 125,
- zigbeeField: 'temperature',
- },
- pressure: {
- category: DEVICE_FEATURE_CATEGORIES.PRESSURE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- unit: DEVICE_FEATURE_UNITS.HECTO_PASCAL,
- name: 'Pressure Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 10000,
- zigbeeField: 'pressure',
- },
- button: {
- category: DEVICE_FEATURE_CATEGORIES.BUTTON,
- type: DEVICE_FEATURE_TYPES.BUTTON.CLICK,
- name: 'Button',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'action',
- },
- switch: {
- category: DEVICE_FEATURE_CATEGORIES.SWITCH,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Switch (On/Off)',
- read_only: false,
- has_feedback: true,
- min: 0,
- max: 1,
- zigbeeField: 'state',
- },
- switch_sensor: {
- category: DEVICE_FEATURE_CATEGORIES.SWITCH,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Switch Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'state',
- },
- power: {
- category: DEVICE_FEATURE_CATEGORIES.SWITCH,
- type: DEVICE_FEATURE_TYPES.SWITCH.POWER,
- unit: DEVICE_FEATURE_UNITS.WATT,
- name: 'Power consumption',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'power',
- },
- current: {
- category: DEVICE_FEATURE_CATEGORIES.SWITCH,
- type: DEVICE_FEATURE_TYPES.SWITCH.CURRENT,
- unit: DEVICE_FEATURE_UNITS.AMPERE,
- name: 'Switch Current',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1000,
- zigbeeField: 'current',
- },
- voltage: {
- category: DEVICE_FEATURE_CATEGORIES.SWITCH,
- type: DEVICE_FEATURE_TYPES.SWITCH.VOLTAGE,
- unit: DEVICE_FEATURE_UNITS.VOLT,
- name: 'Switch Voltage',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1000,
- zigbeeField: 'voltage',
- },
- energy: {
- category: DEVICE_FEATURE_CATEGORIES.SWITCH,
- type: DEVICE_FEATURE_TYPES.SWITCH.ENERGY,
- unit: DEVICE_FEATURE_UNITS.KILOWATT_HOUR,
- name: 'Energy consumption',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 10000,
- zigbeeField: 'energy',
- },
- light: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Light',
- read_only: false,
- has_feedback: true,
- min: 0,
- max: 1,
- zigbeeField: 'state',
- },
- brightness: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT,
- type: DEVICE_FEATURE_TYPES.LIGHT.BRIGHTNESS,
- name: 'Light Brightness',
- read_only: false,
- has_feedback: false,
- min: 0,
- max: 255,
- zigbeeField: 'brightness',
- },
- color_temperature: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT,
- type: DEVICE_FEATURE_TYPES.LIGHT.TEMPERATURE,
- name: 'Light Temperature',
- read_only: false,
- has_feedback: false,
- min: 150,
- max: 500,
- zigbeeField: 'color_temp',
- },
- color: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT,
- type: DEVICE_FEATURE_TYPES.LIGHT.COLOR,
- name: 'Light Color',
- read_only: false,
- has_feedback: false,
- min: 0,
- max: 16777215,
- zigbeeField: 'color',
- },
- gas: {
- category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- name: 'Smoke Sensor',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- zigbeeField: 'gas',
- },
- gas_density: {
- category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- name: 'Gas Density',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1000,
- zigbeeField: 'gas',
- },
- co2: {
- category: DEVICE_FEATURE_CATEGORIES.CO2_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- name: 'CO2 Concentration',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 10000,
- zigbeeField: 'co2',
- },
-};
-
-module.exports = {
- features,
-};
diff --git a/server/services/zigbee2mqtt/utils/loadFeatures.js b/server/services/zigbee2mqtt/utils/loadFeatures.js
deleted file mode 100644
index fe72e670a2..0000000000
--- a/server/services/zigbee2mqtt/utils/loadFeatures.js
+++ /dev/null
@@ -1,33 +0,0 @@
-const { features } = require('./features');
-const { getFeaturesByModel } = require('../model');
-
-/**
- * @description Retreive feature related to device.
- * @param {string} name - Device name.
- * @param {string} model - Device model.
- * @param {boolean} addBattery - Automatically add battery feature.
- * @returns {Object} Device for Gladys.
- * @example
- * loadFeatures('MyDevice', 'MODEL', true);
- */
-function loadFeatures(name, model, addBattery) {
- const matchingFeatures = getFeaturesByModel(model);
- const loadedFeatures = matchingFeatures.map((f) => {
- return Object.assign({}, f);
- });
-
- if (addBattery) {
- loadedFeatures.push(Object.assign({}, features.battery));
- }
-
- loadedFeatures.forEach((feature) => {
- feature.external_id = `zigbee2mqtt:${name}:${feature.category}:${feature.type}:${feature.zigbeeField}`;
- feature.selector = feature.external_id;
- });
-
- return loadedFeatures;
-}
-
-module.exports = {
- loadFeatures,
-};
diff --git a/server/test/services/zigbee2mqtt/utils/loadFeatures.test.js b/server/test/services/zigbee2mqtt/utils/loadFeatures.test.js
deleted file mode 100644
index de2d16d7ed..0000000000
--- a/server/test/services/zigbee2mqtt/utils/loadFeatures.test.js
+++ /dev/null
@@ -1,59 +0,0 @@
-const { assert } = require('chai');
-const { loadFeatures } = require('../../../../services/zigbee2mqtt/utils/loadFeatures');
-
-const name = 'Device';
-const model = 'WXKG11LM';
-
-const expectedFeaturesWithBattery = [
- {
- category: 'button',
- type: 'click',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- name: 'Button',
- external_id: 'zigbee2mqtt:Device:button:click:action',
- selector: 'zigbee2mqtt:Device:button:click:action',
- zigbeeField: 'action',
- },
- {
- category: 'battery',
- type: 'integer',
- unit: 'percent',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 100,
- name: 'Battery',
- external_id: 'zigbee2mqtt:Device:battery:integer:battery',
- selector: 'zigbee2mqtt:Device:battery:integer:battery',
- zigbeeField: 'battery',
- },
-];
-
-const expectedFeatures = [
- {
- category: 'button',
- type: 'click',
- read_only: true,
- has_feedback: false,
- min: 0,
- max: 1,
- name: 'Button',
- external_id: 'zigbee2mqtt:Device:button:click:action',
- selector: 'zigbee2mqtt:Device:button:click:action',
- zigbeeField: 'action',
- },
-];
-
-describe('zigbee2mqttService loadFeatures', () => {
- it('should return features with battery', () => {
- const features = loadFeatures(name, model, true);
- return assert.deepEqual(features, expectedFeaturesWithBattery);
- });
- it('should return features without battery', () => {
- const features = loadFeatures(name, model, false);
- return assert.deepEqual(features, expectedFeatures);
- });
-});
From 576dcc17ddf6c0e677e38a92fd8067eb70b31986 Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Sun, 19 Sep 2021 14:34:37 +0200
Subject: [PATCH 2/9] Zigbee2mqtt auto-build features
---
front/src/config/i18n/en.json | 2 +
front/src/config/i18n/fr.json | 2 +
.../zigbee2mqtt/exposes/binaryType.js | 91 +++++++
.../zigbee2mqtt/exposes/compositeType.js | 15 ++
.../services/zigbee2mqtt/exposes/enumType.js | 39 +++
server/services/zigbee2mqtt/exposes/index.js | 9 +
.../zigbee2mqtt/exposes/numericType.js | 238 +++++++++++++++++
.../zigbee2mqtt/lib/handleMqttMessage.js | 4 +-
.../zigbee2mqtt/utils/convertDevice.js | 36 +--
.../utils/features/buildFeature.js | 88 +++++++
.../utils/features/completeFeature.js | 24 ++
.../utils/features/mapDefinition.js | 20 ++
.../zigbee2mqtt/utils/features/mapExpose.js | 31 +++
.../zigbee2mqtt/utils/features/mapUnit.js | 41 +++
.../zigbee2mqtt/lib/handleMqttMessage.test.js | 101 +------
.../lib/payloads/event_device_result.json | 106 ++++++++
.../lib/payloads/mqtt_devices_get.json | 246 ++++++++++++++++++
.../zigbee2mqtt/utils/convertDevice.test.js | 96 +++----
.../utils/feature/buildFeature.test.js | 227 ++++++++++++++++
.../utils/feature/completeFeature.test.js | 16 ++
.../zigbee2mqtt/utils/feature/mapUnit.test.js | 31 +++
server/utils/constants.js | 1 +
22 files changed, 1297 insertions(+), 167 deletions(-)
create mode 100644 server/services/zigbee2mqtt/exposes/binaryType.js
create mode 100644 server/services/zigbee2mqtt/exposes/compositeType.js
create mode 100644 server/services/zigbee2mqtt/exposes/enumType.js
create mode 100644 server/services/zigbee2mqtt/exposes/index.js
create mode 100644 server/services/zigbee2mqtt/exposes/numericType.js
create mode 100644 server/services/zigbee2mqtt/utils/features/buildFeature.js
create mode 100644 server/services/zigbee2mqtt/utils/features/completeFeature.js
create mode 100644 server/services/zigbee2mqtt/utils/features/mapDefinition.js
create mode 100644 server/services/zigbee2mqtt/utils/features/mapExpose.js
create mode 100644 server/services/zigbee2mqtt/utils/features/mapUnit.js
create mode 100644 server/test/services/zigbee2mqtt/lib/payloads/event_device_result.json
create mode 100644 server/test/services/zigbee2mqtt/lib/payloads/mqtt_devices_get.json
create mode 100644 server/test/services/zigbee2mqtt/utils/feature/buildFeature.test.js
create mode 100644 server/test/services/zigbee2mqtt/utils/feature/completeFeature.test.js
create mode 100644 server/test/services/zigbee2mqtt/utils/feature/mapUnit.test.js
diff --git a/front/src/config/i18n/en.json b/front/src/config/i18n/en.json
index 80dec54b5e..acf5805f53 100644
--- a/front/src/config/i18n/en.json
+++ b/front/src/config/i18n/en.json
@@ -1525,6 +1525,7 @@
"kilowatt": "Kilowatt (kW)",
"kilowatt-hour": "Kilowatt hour (kWh)",
"ampere": "Ampere (A)",
+ "millivolt": "Millivolt (mV)",
"volt": "Volt (V)",
"ppm": "Parts per million (ppm)",
"cm": "Centimeter (cm)",
@@ -1541,6 +1542,7 @@
"kilowatt": "kW",
"kilowatt-hour": "kWh",
"ampere": "A",
+ "millivolt": "mV",
"volt": "V",
"ppm": "ppm",
"cm": "cm",
diff --git a/front/src/config/i18n/fr.json b/front/src/config/i18n/fr.json
index 6d9c1dec74..6bc240ca73 100644
--- a/front/src/config/i18n/fr.json
+++ b/front/src/config/i18n/fr.json
@@ -1525,6 +1525,7 @@
"kilowatt": "Kilowatt",
"kilowatt-hour": "Kilowatt heure (kWh)",
"ampere": "Ampère (A)",
+ "millivolt": "Millivolt (mV)",
"volt": "Volt (V)",
"ppm": "Partie par million (ppm)",
"cm": "Centimètre (cm)",
@@ -1541,6 +1542,7 @@
"kilowatt": "kW",
"kilowatt-hour": "kWh",
"ampere": "A",
+ "millivolt": "mV",
"volt": "V",
"ppm": "ppm",
"cm": "cm",
diff --git a/server/services/zigbee2mqtt/exposes/binaryType.js b/server/services/zigbee2mqtt/exposes/binaryType.js
new file mode 100644
index 0000000000..949c97db1a
--- /dev/null
+++ b/server/services/zigbee2mqtt/exposes/binaryType.js
@@ -0,0 +1,91 @@
+const { DEVICE_FEATURE_CATEGORIES, DEVICE_FEATURE_TYPES } = require('../../../utils/constants');
+
+module.exports = {
+ type: 'binary',
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.BINARY,
+ min: 0,
+ max: 1,
+ },
+ names: {
+ /*
+ auto_lock: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ away_mode: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.FAN,
+ type: DEVICE_FEATURE_TYPES.FAN.BINARY,
+ },
+ },
+ carbon_monoxide: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.MONOXIDE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ },
+ },
+ */
+ contact: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.OPENING_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ eco_mode: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ occupancy: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.MOTION_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ interlock: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ presence: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.MOTION_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ smoke: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ state: {
+ types: {
+ light: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT,
+ type: DEVICE_FEATURE_TYPES.LIGHT.BINARY,
+ },
+ lock: {
+ category: DEVICE_FEATURE_CATEGORIES.ACCESS_CONTROL,
+ type: DEVICE_FEATURE_TYPES.ACCESS_CONTROL.MODE,
+ },
+ switch: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.BINARY,
+ },
+ },
+ },
+ water_leak: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.LEAK_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ },
+};
diff --git a/server/services/zigbee2mqtt/exposes/compositeType.js b/server/services/zigbee2mqtt/exposes/compositeType.js
new file mode 100644
index 0000000000..2db3ea9adc
--- /dev/null
+++ b/server/services/zigbee2mqtt/exposes/compositeType.js
@@ -0,0 +1,15 @@
+const { DEVICE_FEATURE_CATEGORIES, DEVICE_FEATURE_TYPES } = require('../../../utils/constants');
+
+module.exports = {
+ type: 'composite',
+ names: {
+ color_xy: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT,
+ type: DEVICE_FEATURE_TYPES.LIGHT.COLOR,
+ min: 0,
+ max: 16777215,
+ },
+ },
+ },
+};
diff --git a/server/services/zigbee2mqtt/exposes/enumType.js b/server/services/zigbee2mqtt/exposes/enumType.js
new file mode 100644
index 0000000000..1ddf759394
--- /dev/null
+++ b/server/services/zigbee2mqtt/exposes/enumType.js
@@ -0,0 +1,39 @@
+const { DEVICE_FEATURE_CATEGORIES, DEVICE_FEATURE_TYPES } = require('../../../utils/constants');
+
+module.exports = {
+ type: 'enum',
+ feature: {
+ min: 0,
+ max: 1,
+ },
+ names: {
+ action: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.BUTTON,
+ type: DEVICE_FEATURE_TYPES.BUTTON.CLICK,
+ },
+ },
+ /*
+ fan_mode: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.FAN,
+ type: DEVICE_FEATURE_TYPES.FAN.SPEED,
+ },
+ },
+ state: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.CURTAIN,
+ type: DEVICE_FEATURE_TYPES.CURTAIN.STATE,
+ min: 0,
+ max: 2,
+ },
+ }
+ system_mode: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.FAN,
+ type: DEVICE_FEATURE_TYPES.FAN.MODE,
+ },
+ },
+ */
+ },
+};
diff --git a/server/services/zigbee2mqtt/exposes/index.js b/server/services/zigbee2mqtt/exposes/index.js
new file mode 100644
index 0000000000..6e5e303293
--- /dev/null
+++ b/server/services/zigbee2mqtt/exposes/index.js
@@ -0,0 +1,9 @@
+const binaryType = require('./binaryType');
+const numericType = require('./numericType');
+const enumType = require('./enumType');
+
+module.exports = {
+ [binaryType.type]: binaryType,
+ [numericType.type]: numericType,
+ [enumType.type]: enumType,
+};
diff --git a/server/services/zigbee2mqtt/exposes/numericType.js b/server/services/zigbee2mqtt/exposes/numericType.js
new file mode 100644
index 0000000000..7d0b0e07dc
--- /dev/null
+++ b/server/services/zigbee2mqtt/exposes/numericType.js
@@ -0,0 +1,238 @@
+const { DEVICE_FEATURE_CATEGORIES, DEVICE_FEATURE_TYPES, DEVICE_FEATURE_UNITS } = require('../../../utils/constants');
+
+module.exports = {
+ type: 'numeric',
+ feature: {
+ min: 0,
+ max: 10000,
+ },
+ names: {
+ battery: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.BATTERY,
+ type: DEVICE_FEATURE_TYPES.SENSOR.INTEGER,
+ unit: DEVICE_FEATURE_UNITS.PERCENT,
+ min: 0,
+ max: 100,
+ },
+ },
+ brightness: {
+ types: {
+ light: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT,
+ type: DEVICE_FEATURE_TYPES.LIGHT.BRIGHTNESS,
+ min: 0,
+ max: 255,
+ },
+ },
+ },
+ co2: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.CO2_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.PPM,
+ },
+ },
+ color_temp: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT,
+ type: DEVICE_FEATURE_TYPES.LIGHT.TEMPERATURE,
+ min: 150,
+ max: 500,
+ },
+ },
+ /*
+ confort_temperature: {
+ feature: {
+ },
+ },
+ */
+ current: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.CURRENT,
+ unit: DEVICE_FEATURE_UNITS.AMPERE,
+ min: 0,
+ max: 1000,
+ },
+ },
+ current_phase_b: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.CURRENT,
+ unit: DEVICE_FEATURE_UNITS.AMPERE,
+ min: 0,
+ max: 1000,
+ },
+ },
+ current_phase_c: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.CURRENT,
+ unit: DEVICE_FEATURE_UNITS.AMPERE,
+ min: 0,
+ max: 1000,
+ },
+ },
+ cpu_temperature: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.CELSIUS,
+ min: -100,
+ max: 150,
+ },
+ },
+ device_temperature: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.CELSIUS,
+ min: -100,
+ max: 150,
+ },
+ },
+ eco2: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.CO2_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.PPM,
+ },
+ },
+ energy: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.ENERGY,
+ unit: DEVICE_FEATURE_UNITS.KILOWATT_HOUR,
+ },
+ },
+ formaldehyd: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ },
+ },
+ gas: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ },
+ },
+ /*
+ hue: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT,
+ type: DEVICE_FEATURE_TYPES.LIGHT.HUE,
+ min: 150?,
+ max: 500?,
+ },
+ },
+ */
+ humidity: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.HUMIDITY_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.PERCENT,
+ min: 0,
+ max: 100,
+ },
+ },
+ illuminance: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ min: 0,
+ max: 10000,
+ },
+ },
+ illuminance_lux: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.LUX,
+ min: 0,
+ max: 10000,
+ },
+ },
+ local_temperature: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.CELSIUS,
+ min: -100,
+ max: 150,
+ },
+ },
+ /*
+ position: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.CURTAIN,
+ type: DEVICE_FEATURE_TYPES.CURTAIN.POSITION,
+ unit: DEVICE_FEATURE_UNITS.PERCENT,
+ min: 0,
+ max: 100,
+ },
+ },
+ */
+ power: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.POWER,
+ unit: DEVICE_FEATURE_UNITS.WATT,
+ },
+ },
+ pressure: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.PRESSURE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.HECTO_PASCAL,
+ },
+ },
+ /*
+ saturation: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.LIGHT,
+ type: DEVICE_FEATURE_TYPES.LIGHT.SATURATION,
+ min: 150?,
+ max: 500?,
+ },
+ },
+ */
+ temperature: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
+ unit: DEVICE_FEATURE_UNITS.CELSIUS,
+ min: -100,
+ max: 150,
+ },
+ },
+ vibration: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.VIBRATION_SENSOR,
+ type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
+ },
+ },
+ voltage: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.VOLTAGE,
+ unit: DEVICE_FEATURE_UNITS.VOLT,
+ },
+ },
+ voltage_phase_b: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.VOLTAGE,
+ unit: DEVICE_FEATURE_UNITS.VOLT,
+ },
+ },
+ voltage_phase_c: {
+ feature: {
+ category: DEVICE_FEATURE_CATEGORIES.SWITCH,
+ type: DEVICE_FEATURE_TYPES.SWITCH.VOLTAGE,
+ unit: DEVICE_FEATURE_UNITS.VOLT,
+ },
+ },
+ },
+};
diff --git a/server/services/zigbee2mqtt/lib/handleMqttMessage.js b/server/services/zigbee2mqtt/lib/handleMqttMessage.js
index af1231b1c5..0e3a3a51a1 100644
--- a/server/services/zigbee2mqtt/lib/handleMqttMessage.js
+++ b/server/services/zigbee2mqtt/lib/handleMqttMessage.js
@@ -21,14 +21,12 @@ function handleMqttMessage(topic, message) {
});
switch (topic) {
- case 'zigbee2mqtt/bridge/config/devices': {
+ case 'zigbee2mqtt/bridge/devices': {
logger.log('Getting config devices from Zigbee2mqtt');
const devices = JSON.parse(message);
const convertedDevices = devices
// Remove Coordinator
.filter((d) => d.type !== TYPE_COORDINATOR)
- // Remove Empty models
- .filter((d) => d.model && d.model !== '')
// Remove existing devices
.filter((d) => {
const existingDevice = this.gladys.stateManager.get('deviceByExternalId', `zigbee2mqtt:${d.friendly_name}`);
diff --git a/server/services/zigbee2mqtt/utils/convertDevice.js b/server/services/zigbee2mqtt/utils/convertDevice.js
index 393d99e6c7..7f3afe0836 100644
--- a/server/services/zigbee2mqtt/utils/convertDevice.js
+++ b/server/services/zigbee2mqtt/utils/convertDevice.js
@@ -1,6 +1,6 @@
-const { loadFeatures } = require('./loadFeatures');
const logger = require('../../../utils/logger');
const { DEVICE_FEATURE_CATEGORIES } = require('../../../../server/utils/constants');
+const { mapDefinition } = require('./features/mapDefinition');
/**
* @description Converts an MQTT device to a Gladys device.
@@ -8,37 +8,27 @@ const { DEVICE_FEATURE_CATEGORIES } = require('../../../../server/utils/constant
* @param {string} serviceId - Service ID.
* @returns {Object} Device for Gladys.
* @example
- * convertDevice({ friendly_name: 'name', model: 'featureMapper' }, '6a37dd9d-48c7-4d09-a7bb-33f257edb78d');
+ * convertDevice({ friendly_name: 'name', definition: {} }, '6a37dd9d-48c7-4d09-a7bb-33f257edb78d');
*/
function convertDevice(device, serviceId) {
- const features = loadFeatures(device.friendly_name, device.model, device.powerSource === 'Battery');
+ const { friendly_name: name, definition = {} } = device;
+ const { model } = definition;
+ const features = mapDefinition(name, definition);
- // Not managed device
- if (features.length === 0 || (features.length === 1 && features[0].category === DEVICE_FEATURE_CATEGORIES.BATTERY)) {
- const gladysDevice = {
- name: device.friendly_name,
- external_id: `zigbee2mqtt:${device.friendly_name}`,
- model: device.model,
- features,
- should_poll: false,
- service_id: serviceId,
- supported: false,
- };
- logger.debug(`Device ${device.friendly_name} / model ${device.model} NOT managed by Gladys`);
- logger.debug(gladysDevice);
- return gladysDevice;
- }
+ // Device is not managed if no feature found, or only battery feature is available.
+ const supported = features.findIndex((f) => f.category !== DEVICE_FEATURE_CATEGORIES.BATTERY) >= 0;
const gladysDevice = {
- name: device.friendly_name,
- external_id: `zigbee2mqtt:${device.friendly_name}`,
- model: device.model,
+ name,
+ model,
+ external_id: `zigbee2mqtt:${name}`,
features,
should_poll: false,
service_id: serviceId,
- supported: true,
+ supported,
};
- logger.debug(`Device ${device.friendly_name} / model ${device.model} managed by Gladys`);
+
+ logger.debug(`Device ${name} / model ${model} ${supported ? '' : 'NOT'} managed by Gladys`);
logger.debug(gladysDevice);
return gladysDevice;
}
diff --git a/server/services/zigbee2mqtt/utils/features/buildFeature.js b/server/services/zigbee2mqtt/utils/features/buildFeature.js
new file mode 100644
index 0000000000..1e3e5ec839
--- /dev/null
+++ b/server/services/zigbee2mqtt/utils/features/buildFeature.js
@@ -0,0 +1,88 @@
+const exposesMap = require('../../exposes');
+const { mapUnit } = require('./mapUnit');
+const { completeFeature } = require('./completeFeature');
+
+/**
+ * @description Load feature from parent type.
+ * @param {Object} types - Zigbee "expose" parent type features.
+ * @param {string} parentType - Requested parent type.
+ * @returns {Object} The related Gladys feature, or undefined.
+ *
+ * @example buildByParentType({ switch: {}, light: {}}, 'light');
+ */
+function buildByParentType(types = {}, parentType) {
+ return types[parentType];
+}
+
+/**
+ * @description Load feature from property name, completed by parent type.
+ *
+ * @param {Object} names - Zigbee "expose" proerty name features.
+ * @param {string} name - Zigbee "expose" property name.
+ * @param {string} parentType - Requested parent type.
+ * @returns {Object} The related Gladys feature, or undefined.
+ *
+ * @example buildByName({ state: {}}, 'state', 'light');
+ */
+function buildByName(names = {}, name, parentType) {
+ const { types = {}, feature } = names[name] || {};
+ const byType = buildByParentType(types, parentType);
+
+ if (!byType && !feature) {
+ return undefined;
+ }
+
+ return { ...(feature || {}), ...(byType || {}) };
+}
+
+/**
+ * @description Build a Gladys feature according to Zigbee "expose" values.
+ * @param {string} deviceName - Device friendly name.
+ * @param {Object} expose - Zigbee "expose" values.
+ * @param {string} parentType - Requested parent type.
+ * @returns {Object} The related Gladys feature, or undefined.
+ *
+ * @example buildFeature('MyDevice', {}, 'light');
+ */
+function buildFeature(deviceName, expose = {}, parentType) {
+ const { type, name, property, access, value_min: minValue, value_max: maxValue, unit: deviceUnit, values } = expose;
+ const { names = {}, feature } = exposesMap[type] || {};
+ const byName = buildByName(names, name, parentType);
+
+ if (!byName) {
+ return undefined;
+ }
+
+ // Read only ?
+ // eslint-disable-next-line no-bitwise
+ const readOnly = (access & 2) === 0;
+
+ // Has feedback ?
+ // eslint-disable-next-line no-bitwise
+ const hasFeedback = !readOnly && (access & 1) === 1;
+
+ const createdFeature = { read_only: readOnly, has_feedback: hasFeedback, ...(feature || {}), ...(byName || {}) };
+
+ // Min value
+ const min = minValue !== undefined ? minValue : createdFeature.min;
+
+ // Max value
+ let { max } = createdFeature;
+ if (maxValue !== undefined) {
+ max = maxValue;
+ } else if (values !== undefined) {
+ max = values.length;
+ }
+
+ // Unit
+ const unit = mapUnit(deviceUnit, createdFeature.unit);
+
+ // Add missing properties
+ return completeFeature(deviceName, { ...createdFeature, min, max, unit }, property);
+}
+
+module.exports = {
+ buildByParentType,
+ buildByName,
+ buildFeature,
+};
diff --git a/server/services/zigbee2mqtt/utils/features/completeFeature.js b/server/services/zigbee2mqtt/utils/features/completeFeature.js
new file mode 100644
index 0000000000..6929716921
--- /dev/null
+++ b/server/services/zigbee2mqtt/utils/features/completeFeature.js
@@ -0,0 +1,24 @@
+const { addSelector } = require('../../../../utils/addSelector');
+
+/**
+ * @description Complete feature with externalId and selector generated values.
+ *
+ * @param {string} deviceName - Zigbee friendly device name.
+ * @param {Object} feature - Related Gladys feature.
+ * @param {string} property - Related Zigbee property.
+ * @returns {Object} Completed Galdys feature.
+ *
+ * @example completeFeature('MyDevice', { category: 'light', type: 'binary' }, 'state');
+ */
+function completeFeature(deviceName, feature, property) {
+ const { category, type } = feature;
+ const externalId = `zigbee2mqtt:${deviceName}:${category}:${type}:${property}`;
+ const name = `${property.charAt(0).toUpperCase() + property.slice(1).replace(/_/g, ' ')}`;
+ const completedFeature = { name, ...feature, external_id: externalId, selector: externalId };
+ addSelector(completedFeature);
+ return completedFeature;
+}
+
+module.exports = {
+ completeFeature,
+};
diff --git a/server/services/zigbee2mqtt/utils/features/mapDefinition.js b/server/services/zigbee2mqtt/utils/features/mapDefinition.js
new file mode 100644
index 0000000000..301b4a603a
--- /dev/null
+++ b/server/services/zigbee2mqtt/utils/features/mapDefinition.js
@@ -0,0 +1,20 @@
+const { mapExpose } = require('./mapExpose');
+
+/**
+ * @description Build Gladys features according to Zigbee device.
+ * @param {string} deviceName - Device name.
+ * @param {Object} definition - Zigbee device definition.
+ * @returns {Array} The related Gladys features.
+ *
+ * @example mapDefinition('MyDevice', {});
+ */
+function mapDefinition(deviceName, definition = {}) {
+ const { exposes = [] } = definition;
+
+ // Build feature according to device
+ return exposes.flatMap((e) => mapExpose(deviceName, e));
+}
+
+module.exports = {
+ mapDefinition,
+};
diff --git a/server/services/zigbee2mqtt/utils/features/mapExpose.js b/server/services/zigbee2mqtt/utils/features/mapExpose.js
new file mode 100644
index 0000000000..e4ed686d64
--- /dev/null
+++ b/server/services/zigbee2mqtt/utils/features/mapExpose.js
@@ -0,0 +1,31 @@
+const { buildFeature } = require('./buildFeature');
+
+/**
+ * @description Build a Gladys feature according to Zigbee "expose" and "features" values.
+ * @param {string} deviceName - Device friendly name.
+ * @param {Object} expose - Zigbee "expose" values.
+ * @param {string} parentType - Requested parent type.
+ * @returns {Object} The related Gladys feature, or undefined.
+ *
+ * @example mapExpose('MyDevice', {}, 'light');
+ */
+function mapExpose(deviceName, expose, parentType = undefined) {
+ const { type, features = [] } = expose;
+
+ const matchingFeatures = [];
+
+ // Merge default with specific
+ const feature = buildFeature(deviceName, expose, parentType);
+ if (feature) {
+ matchingFeatures.push(feature);
+ }
+
+ // Map exposed sub-features recursivly
+ features.flatMap((f) => mapExpose(deviceName, f, parentType || type)).forEach((f) => matchingFeatures.push(f));
+
+ return matchingFeatures;
+}
+
+module.exports = {
+ mapExpose,
+};
diff --git a/server/services/zigbee2mqtt/utils/features/mapUnit.js b/server/services/zigbee2mqtt/utils/features/mapUnit.js
new file mode 100644
index 0000000000..bf6c258445
--- /dev/null
+++ b/server/services/zigbee2mqtt/utils/features/mapUnit.js
@@ -0,0 +1,41 @@
+const { DEVICE_FEATURE_UNITS } = require('../../../../utils/constants');
+
+/**
+ * @description Transform Zigbee unit to Gladys unit.
+ *
+ * @param {string} deviceUnit - Zigbee unit.
+ * @param {string} featureUnit - Default unit.
+ * @returns {string} Tranformed unit.
+ *
+ * @example mapUnit('°C', 'celsius');
+ */
+function mapUnit(deviceUnit, featureUnit) {
+ switch (deviceUnit) {
+ case '%':
+ return DEVICE_FEATURE_UNITS.PERCENT;
+ case 'hPa':
+ return DEVICE_FEATURE_UNITS.HECTO_PASCAL;
+ case 'ppm':
+ return DEVICE_FEATURE_UNITS.PPM;
+ case 'A':
+ return DEVICE_FEATURE_UNITS.AMPERE;
+ case 'V':
+ return DEVICE_FEATURE_UNITS.VOLT;
+ case 'mV':
+ return DEVICE_FEATURE_UNITS.MILLI_VOLT;
+ case 'W':
+ return DEVICE_FEATURE_UNITS.WATT;
+ case 'kWh':
+ return DEVICE_FEATURE_UNITS.KILOWATT_HOUR;
+ case '°C':
+ return DEVICE_FEATURE_UNITS.CELSIUS;
+ case '°F':
+ return DEVICE_FEATURE_UNITS.FAHRENHEIT;
+ default:
+ return featureUnit;
+ }
+}
+
+module.exports = {
+ mapUnit,
+};
diff --git a/server/test/services/zigbee2mqtt/lib/handleMqttMessage.test.js b/server/test/services/zigbee2mqtt/lib/handleMqttMessage.test.js
index 4cde5b8c2d..795f90b011 100644
--- a/server/test/services/zigbee2mqtt/lib/handleMqttMessage.test.js
+++ b/server/test/services/zigbee2mqtt/lib/handleMqttMessage.test.js
@@ -3,6 +3,9 @@ const sinon = require('sinon');
const { assert, fake } = sinon;
const proxyquire = require('proxyquire').noCallThru();
+const zigbeeDevices = require('./payloads/mqtt_devices_get.json');
+const expectedDevicesPayload = require('./payloads/event_device_result.json');
+
const { EVENTS, WEBSOCKET_MESSAGE_TYPES } = require('../../../../utils/constants');
const Zigbee2mqttManager = proxyquire('../../../../services/zigbee2mqtt/lib', {});
@@ -21,103 +24,7 @@ const gladys = {
},
};
-const zigbeeDevices = `[
- {
- "type":"Coordinator"
- },
- {
- "friendly_name":"0x00158d0005828ece",
- "model":"WSDCGQ11LM",
- "powerSource":"Battery",
- "type":"EndDevice"
- },
- {
- "friendly_name":"0x00158d0005828eca",
- "model":"fakeModel",
- "type":"EndDevice"
- },
- {
- "friendly_name":"0x00158d0005828ece",
- "model":"WSDCGQ11LM",
- "powerSource":"Battery",
- "type":"EndDevice"
- }
- ]`;
-
const serviceId = 'f87b7af2-ca8e-44fc-b754-444354b42fee';
-const expectedDevicesPayload = [
- {
- external_id: 'zigbee2mqtt:0x00158d0005828eca',
- features: [],
- model: 'fakeModel',
- name: '0x00158d0005828eca',
- service_id: 'f87b7af2-ca8e-44fc-b754-444354b42fee',
- should_poll: false,
- supported: false,
- },
- {
- external_id: 'zigbee2mqtt:0x00158d0005828ece',
- features: [
- {
- category: 'temperature-sensor',
- external_id: 'zigbee2mqtt:0x00158d0005828ece:temperature-sensor:decimal:temperature',
- has_feedback: false,
- max: 125,
- min: -50,
- read_only: true,
- name: 'Temperature',
- selector: 'zigbee2mqtt:0x00158d0005828ece:temperature-sensor:decimal:temperature',
- type: 'decimal',
- unit: 'celsius',
- zigbeeField: 'temperature',
- },
- {
- category: 'humidity-sensor',
- external_id: 'zigbee2mqtt:0x00158d0005828ece:humidity-sensor:decimal:humidity',
- has_feedback: false,
- max: 100,
- min: 0,
- read_only: true,
- name: 'Humidity',
- selector: 'zigbee2mqtt:0x00158d0005828ece:humidity-sensor:decimal:humidity',
- type: 'decimal',
- unit: 'percent',
- zigbeeField: 'humidity',
- },
- {
- category: 'pressure-sensor',
- external_id: 'zigbee2mqtt:0x00158d0005828ece:pressure-sensor:decimal:pressure',
- has_feedback: false,
- max: 10000,
- min: 0,
- name: 'Pressure Sensor',
- read_only: true,
- selector: 'zigbee2mqtt:0x00158d0005828ece:pressure-sensor:decimal:pressure',
- type: 'decimal',
- unit: 'hPa',
- zigbeeField: 'pressure',
- },
- {
- category: 'battery',
- external_id: 'zigbee2mqtt:0x00158d0005828ece:battery:integer:battery',
- has_feedback: false,
- max: 100,
- min: 0,
- read_only: true,
- name: 'Battery',
- selector: 'zigbee2mqtt:0x00158d0005828ece:battery:integer:battery',
- type: 'integer',
- unit: 'percent',
- zigbeeField: 'battery',
- },
- ],
- model: 'WSDCGQ11LM',
- name: '0x00158d0005828ece',
- service_id: 'f87b7af2-ca8e-44fc-b754-444354b42fee',
- should_poll: false,
- supported: true,
- },
-];
describe('zigbee2mqtt handleMqttMessage', () => {
// PREPARE
@@ -141,7 +48,7 @@ describe('zigbee2mqtt handleMqttMessage', () => {
.returns(false);
zigbee2mqttManager.gladys.stateManager.get = stateManagerGetStub;
// EXECUTE
- await zigbee2mqttManager.handleMqttMessage('zigbee2mqtt/bridge/config/devices', zigbeeDevices);
+ await zigbee2mqttManager.handleMqttMessage('zigbee2mqtt/bridge/devices', JSON.stringify(zigbeeDevices));
// ASSERT
assert.calledWith(gladys.event.emit, EVENTS.WEBSOCKET.SEND_ALL, {
type: WEBSOCKET_MESSAGE_TYPES.ZIGBEE2MQTT.STATUS_CHANGE,
diff --git a/server/test/services/zigbee2mqtt/lib/payloads/event_device_result.json b/server/test/services/zigbee2mqtt/lib/payloads/event_device_result.json
new file mode 100644
index 0000000000..ac77dc0037
--- /dev/null
+++ b/server/test/services/zigbee2mqtt/lib/payloads/event_device_result.json
@@ -0,0 +1,106 @@
+[
+ {
+ "name": "0x00158d0004019127",
+ "model": "WXKG11LM",
+ "external_id": "zigbee2mqtt:0x00158d0004019127",
+ "features": [
+ {
+ "name": "Battery",
+ "read_only": true,
+ "has_feedback": false,
+ "min": 0,
+ "max": 100,
+ "category": "battery",
+ "type": "integer",
+ "unit": "percent",
+ "external_id": "zigbee2mqtt:0x00158d0004019127:battery:integer:battery",
+ "selector": "zigbee2mqtt-0x00158d0004019127-battery-integer-battery"
+ },
+ {
+ "name": "Voltage",
+ "read_only": true,
+ "has_feedback": false,
+ "min": 0,
+ "max": 10000,
+ "category": "switch",
+ "type": "voltage",
+ "unit": "millivolt",
+ "external_id": "zigbee2mqtt:0x00158d0004019127:switch:voltage:voltage",
+ "selector": "zigbee2mqtt-0x00158d0004019127-switch-voltage-voltage"
+ }
+ ],
+ "should_poll": false,
+ "service_id": "f87b7af2-ca8e-44fc-b754-444354b42fee",
+ "supported": true
+ },
+ {
+ "name": "0x00158d00045b2740",
+ "model": "WSDCGQ11LM",
+ "external_id": "zigbee2mqtt:0x00158d00045b2740",
+ "features": [
+ {
+ "name": "Battery",
+ "read_only": true,
+ "has_feedback": false,
+ "min": 0,
+ "max": 100,
+ "category": "battery",
+ "type": "integer",
+ "unit": "percent",
+ "external_id": "zigbee2mqtt:0x00158d00045b2740:battery:integer:battery",
+ "selector": "zigbee2mqtt-0x00158d00045b2740-battery-integer-battery"
+ },
+ {
+ "name": "Temperature",
+ "read_only": true,
+ "has_feedback": false,
+ "min": -100,
+ "max": 150,
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "unit": "celsius",
+ "external_id": "zigbee2mqtt:0x00158d00045b2740:temperature-sensor:decimal:temperature",
+ "selector": "zigbee2mqtt-0x00158d00045b2740-temperature-sensor-decimal-temperature"
+ },
+ {
+ "name": "Humidity",
+ "read_only": true,
+ "has_feedback": false,
+ "min": 0,
+ "max": 100,
+ "category": "humidity-sensor",
+ "type": "decimal",
+ "unit": "percent",
+ "external_id": "zigbee2mqtt:0x00158d00045b2740:humidity-sensor:decimal:humidity",
+ "selector": "zigbee2mqtt-0x00158d00045b2740-humidity-sensor-decimal-humidity"
+ },
+ {
+ "name": "Pressure",
+ "read_only": true,
+ "has_feedback": false,
+ "min": 0,
+ "max": 10000,
+ "category": "pressure-sensor",
+ "type": "decimal",
+ "unit": "hPa",
+ "external_id": "zigbee2mqtt:0x00158d00045b2740:pressure-sensor:decimal:pressure",
+ "selector": "zigbee2mqtt-0x00158d00045b2740-pressure-sensor-decimal-pressure"
+ },
+ {
+ "name": "Voltage",
+ "read_only": true,
+ "has_feedback": false,
+ "min": 0,
+ "max": 10000,
+ "category": "switch",
+ "type": "voltage",
+ "unit": "millivolt",
+ "external_id": "zigbee2mqtt:0x00158d00045b2740:switch:voltage:voltage",
+ "selector": "zigbee2mqtt-0x00158d00045b2740-switch-voltage-voltage"
+ }
+ ],
+ "should_poll": false,
+ "service_id": "f87b7af2-ca8e-44fc-b754-444354b42fee",
+ "supported": true
+ }
+]
diff --git a/server/test/services/zigbee2mqtt/lib/payloads/mqtt_devices_get.json b/server/test/services/zigbee2mqtt/lib/payloads/mqtt_devices_get.json
new file mode 100644
index 0000000000..574aa5d2ec
--- /dev/null
+++ b/server/test/services/zigbee2mqtt/lib/payloads/mqtt_devices_get.json
@@ -0,0 +1,246 @@
+[
+ {
+ "definition": null,
+ "endpoints": {
+ "1": {
+ "bindings": [],
+ "clusters": {
+ "input": ["genBasic", "genTime", "genOta"],
+ "output": ["genPowerCfg", "genPollCtrl", "ssIasZone"]
+ },
+ "configured_reportings": []
+ },
+ "242": {
+ "bindings": [],
+ "clusters": {
+ "input": [],
+ "output": ["greenPower"]
+ },
+ "configured_reportings": []
+ }
+ },
+ "friendly_name": "Coordinator",
+ "ieee_address": "0x00212effff06ddd8",
+ "interview_completed": true,
+ "interviewing": false,
+ "network_address": 0,
+ "supported": false,
+ "type": "Coordinator"
+ },
+ {
+ "definition": {
+ "description": "MiJia wireless switch",
+ "exposes": [
+ {
+ "access": 1,
+ "description": "Remaining battery in %",
+ "name": "battery",
+ "property": "battery",
+ "type": "numeric",
+ "unit": "%",
+ "value_max": 100,
+ "value_min": 0
+ },
+ {
+ "access": 1,
+ "description": "Triggered action (e.g. a button click)",
+ "name": "action",
+ "property": "action",
+ "type": "enum",
+ "values": ["single", "double", "triple", "quadruple", "hold", "release", "many"]
+ },
+ {
+ "access": 1,
+ "description": "Voltage of the battery in millivolts",
+ "name": "voltage",
+ "property": "voltage",
+ "type": "numeric",
+ "unit": "mV"
+ },
+ {
+ "access": 1,
+ "description": "Link quality (signal strength)",
+ "name": "linkquality",
+ "property": "linkquality",
+ "type": "numeric",
+ "unit": "lqi",
+ "value_max": 255,
+ "value_min": 0
+ }
+ ],
+ "model": "WXKG01LM",
+ "supports_ota": false,
+ "vendor": "Xiaomi"
+ },
+ "endpoints": {
+ "1": {
+ "bindings": [],
+ "clusters": {
+ "input": [],
+ "output": []
+ },
+ "configured_reportings": []
+ }
+ },
+ "friendly_name": "0x00158d00033e88d5",
+ "ieee_address": "0x00158d00033e88d5",
+ "interview_completed": true,
+ "interviewing": false,
+ "manufacturer": "LUMI",
+ "model_id": "lumi.sensor_switch",
+ "network_address": 44173,
+ "power_source": "Battery",
+ "supported": true,
+ "type": "EndDevice"
+ },
+ {
+ "date_code": "20180525",
+ "definition": {
+ "description": "Aqara wireless switch",
+ "exposes": [
+ {
+ "access": 1,
+ "description": "Remaining battery in %",
+ "name": "battery",
+ "property": "battery",
+ "type": "numeric",
+ "unit": "%",
+ "value_max": 100,
+ "value_min": 0
+ },
+ {
+ "access": 1,
+ "description": "Voltage of the battery in millivolts",
+ "name": "voltage",
+ "property": "voltage",
+ "type": "numeric",
+ "unit": "mV"
+ },
+ {
+ "access": 1,
+ "description": "Link quality (signal strength)",
+ "name": "linkquality",
+ "property": "linkquality",
+ "type": "numeric",
+ "unit": "lqi",
+ "value_max": 255,
+ "value_min": 0
+ }
+ ],
+ "model": "WXKG11LM",
+ "supports_ota": false,
+ "vendor": "Xiaomi"
+ },
+ "endpoints": {
+ "1": {
+ "bindings": [],
+ "clusters": {
+ "input": ["genBasic", "genMultistateInput", "genIdentify"],
+ "output": ["genBasic"]
+ },
+ "configured_reportings": []
+ }
+ },
+ "friendly_name": "0x00158d0004019127",
+ "ieee_address": "0x00158d0004019127",
+ "interview_completed": true,
+ "interviewing": false,
+ "manufacturer": "LUMI",
+ "model_id": "lumi.remote.b1acn01",
+ "network_address": 47250,
+ "power_source": "Battery",
+ "software_build_id": "3000-0001",
+ "supported": true,
+ "type": "EndDevice"
+ },
+ {
+ "date_code": "20161129",
+ "definition": {
+ "description": "Aqara temperature, humidity and pressure sensor",
+ "exposes": [
+ {
+ "access": 1,
+ "description": "Remaining battery in %",
+ "name": "battery",
+ "property": "battery",
+ "type": "numeric",
+ "unit": "%",
+ "value_max": 100,
+ "value_min": 0
+ },
+ {
+ "access": 1,
+ "description": "Measured temperature value",
+ "name": "temperature",
+ "property": "temperature",
+ "type": "numeric",
+ "unit": "°C"
+ },
+ {
+ "access": 1,
+ "description": "Measured relative humidity",
+ "name": "humidity",
+ "property": "humidity",
+ "type": "numeric",
+ "unit": "%"
+ },
+ {
+ "access": 1,
+ "description": "The measured atmospheric pressure",
+ "name": "pressure",
+ "property": "pressure",
+ "type": "numeric",
+ "unit": "hPa"
+ },
+ {
+ "access": 1,
+ "description": "Voltage of the battery in millivolts",
+ "name": "voltage",
+ "property": "voltage",
+ "type": "numeric",
+ "unit": "mV"
+ },
+ {
+ "access": 1,
+ "description": "Link quality (signal strength)",
+ "name": "linkquality",
+ "property": "linkquality",
+ "type": "numeric",
+ "unit": "lqi",
+ "value_max": 255,
+ "value_min": 0
+ }
+ ],
+ "model": "WSDCGQ11LM",
+ "supports_ota": false,
+ "vendor": "Xiaomi"
+ },
+ "endpoints": {
+ "1": {
+ "bindings": [],
+ "clusters": {
+ "input": [
+ "genBasic",
+ "genIdentify",
+ "msTemperatureMeasurement",
+ "msPressureMeasurement",
+ "msRelativeHumidity"
+ ],
+ "output": ["genBasic", "genGroups"]
+ },
+ "configured_reportings": []
+ }
+ },
+ "friendly_name": "0x00158d00045b2740",
+ "ieee_address": "0x00158d00045b2740",
+ "interview_completed": true,
+ "interviewing": false,
+ "manufacturer": "LUMI",
+ "model_id": "lumi.weather",
+ "network_address": 23007,
+ "power_source": "Battery",
+ "software_build_id": "3000-0001",
+ "supported": true,
+ "type": "EndDevice"
+ }
+]
diff --git a/server/test/services/zigbee2mqtt/utils/convertDevice.test.js b/server/test/services/zigbee2mqtt/utils/convertDevice.test.js
index d4f6f57196..54c299ed07 100644
--- a/server/test/services/zigbee2mqtt/utils/convertDevice.test.js
+++ b/server/test/services/zigbee2mqtt/utils/convertDevice.test.js
@@ -2,57 +2,65 @@ const { assert } = require('chai');
const { convertDevice } = require('../../../../services/zigbee2mqtt/utils/convertDevice');
const serviceId = '6a37dd9d-48c7-4d09-a7bb-33f257edb78d';
-
-const notManagedDevice = {
- friendly_name: 'Not supported device',
- model: 'not_supported_device',
-};
-
-const managedDevice = {
- friendly_name: 'Xiaomi Aqara Sensor',
- model: 'WXKG11LM',
-};
-
-const notManagedGladysDevice = {
- name: notManagedDevice.friendly_name,
- external_id: `zigbee2mqtt:${notManagedDevice.friendly_name}`,
- model: notManagedDevice.model,
- features: [],
- should_poll: false,
- service_id: serviceId,
- supported: false,
-};
-
-const managedGladysDevice = {
- name: managedDevice.friendly_name,
- external_id: `zigbee2mqtt:${managedDevice.friendly_name}`,
- model: managedDevice.model,
- features: [
- {
- category: 'button',
- external_id: `zigbee2mqtt:${managedDevice.friendly_name}:button:click:action`,
- has_feedback: false,
- max: 1,
- min: 0,
- read_only: true,
- name: 'Button',
- selector: `zigbee2mqtt:${managedDevice.friendly_name}:button:click:action`,
- type: 'click',
- zigbeeField: 'action',
- },
- ],
- should_poll: false,
- service_id: serviceId,
- supported: true,
-};
-
describe('zigbee2mqtt convertDevice', () => {
it('should return not managed device', () => {
+ const notManagedDevice = {
+ friendly_name: 'Not supported device',
+ };
+
const result = convertDevice(notManagedDevice, serviceId);
+
+ const notManagedGladysDevice = {
+ name: notManagedDevice.friendly_name,
+ external_id: `zigbee2mqtt:${notManagedDevice.friendly_name}`,
+ model: undefined,
+ features: [],
+ should_poll: false,
+ service_id: serviceId,
+ supported: false,
+ };
return assert.deepEqual(result, notManagedGladysDevice);
});
+
it('should return managed device', () => {
+ const managedDevice = {
+ friendly_name: 'Xiaomi Aqara Sensor',
+ definition: {
+ exposes: [
+ {
+ type: 'enum',
+ name: 'action',
+ property: 'action',
+ },
+ ],
+ model: 'WXKG11LM',
+ },
+ };
+
const result = convertDevice(managedDevice, serviceId);
+
+ const managedGladysDevice = {
+ name: managedDevice.friendly_name,
+ external_id: `zigbee2mqtt:${managedDevice.friendly_name}`,
+ model: 'WXKG11LM',
+ features: [
+ {
+ category: 'button',
+ external_id: `zigbee2mqtt:${managedDevice.friendly_name}:button:click:action`,
+ has_feedback: false,
+ max: 1,
+ min: 0,
+ read_only: true,
+ name: 'Action',
+ selector: `zigbee2mqtt-xiaomi-aqara-sensor-button-click-action`,
+ type: 'click',
+ unit: undefined,
+ },
+ ],
+ should_poll: false,
+ service_id: serviceId,
+ supported: true,
+ };
return assert.deepEqual(result, managedGladysDevice);
});
});
diff --git a/server/test/services/zigbee2mqtt/utils/feature/buildFeature.test.js b/server/test/services/zigbee2mqtt/utils/feature/buildFeature.test.js
new file mode 100644
index 0000000000..dda5974d88
--- /dev/null
+++ b/server/test/services/zigbee2mqtt/utils/feature/buildFeature.test.js
@@ -0,0 +1,227 @@
+const { expect } = require('chai');
+
+const {
+ buildByParentType,
+ buildByName,
+ buildFeature,
+} = require('../../../../../services/zigbee2mqtt/utils/features/buildFeature');
+
+describe('zigbee2mqtt buildByParentType', () => {
+ it(`no type map`, () => {
+ const result = buildByParentType(undefined, undefined);
+ expect(result).eq(undefined);
+ });
+
+ it(`no selected type`, () => {
+ const types = {
+ binary: 'binary',
+ };
+ const result = buildByParentType(types, undefined);
+ expect(result).eq(undefined);
+ });
+
+ it(`get selected type`, () => {
+ const types = {
+ binary: 'binary',
+ };
+ const result = buildByParentType(types, 'binary');
+ expect(result).eq('binary');
+ });
+});
+
+describe('zigbee2mqtt buildByName', () => {
+ it(`all empty`, () => {
+ const result = buildByName(undefined, 'binary', 'light');
+ expect(result).eq(undefined);
+ });
+
+ it(`only by name`, () => {
+ const names = {
+ binary: {
+ feature: {
+ type: 'binary',
+ },
+ },
+ };
+ const result = buildByName(names, 'binary', 'light');
+
+ const expectedResult = { type: 'binary' };
+ expect(result).deep.eq(expectedResult);
+ });
+
+ it(`name and type`, () => {
+ const names = {
+ binary: {
+ feature: {
+ type: 'binary',
+ },
+ types: {
+ light: {
+ category: 'light',
+ },
+ },
+ },
+ };
+ const result = buildByName(names, 'binary', 'light');
+
+ const expectedResult = { type: 'binary', category: 'light' };
+ expect(result).deep.eq(expectedResult);
+ });
+});
+
+describe('zigbee2mqtt buildFeature', () => {
+ it(`no data`, () => {
+ const result = buildFeature('deviceName', undefined, undefined);
+ expect(result).eq(undefined);
+ });
+
+ it(`readOnly = true / hasFeedback = false`, () => {
+ const expose = {
+ type: 'binary',
+ name: 'state',
+ property: 'property',
+ access: 1,
+ };
+ const result = buildFeature('deviceName', expose, 'switch');
+
+ const expectedResult = {
+ category: 'switch',
+ type: 'binary',
+ min: 0,
+ max: 1,
+ read_only: true,
+ has_feedback: false,
+ name: 'Property',
+ external_id: 'zigbee2mqtt:deviceName:switch:binary:property',
+ selector: 'zigbee2mqtt-devicename-switch-binary-property',
+ unit: undefined,
+ };
+
+ expect(result).deep.eq(expectedResult);
+ });
+
+ it(`readOnly = false / hasFeedback = false`, () => {
+ const expose = {
+ type: 'binary',
+ name: 'state',
+ property: 'property',
+ access: 2,
+ };
+ const result = buildFeature('deviceName', expose, 'switch');
+
+ const expectedResult = {
+ category: 'switch',
+ type: 'binary',
+ min: 0,
+ max: 1,
+ read_only: false,
+ has_feedback: false,
+ name: 'Property',
+ external_id: 'zigbee2mqtt:deviceName:switch:binary:property',
+ selector: 'zigbee2mqtt-devicename-switch-binary-property',
+ unit: undefined,
+ };
+
+ expect(result).deep.eq(expectedResult);
+ });
+
+ it(`readOnly = false / hasFeedback = true`, () => {
+ const expose = {
+ type: 'binary',
+ name: 'state',
+ property: 'property',
+ access: 7,
+ };
+ const result = buildFeature('deviceName', expose, 'switch');
+
+ const expectedResult = {
+ category: 'switch',
+ type: 'binary',
+ min: 0,
+ max: 1,
+ read_only: false,
+ has_feedback: true,
+ name: 'Property',
+ external_id: 'zigbee2mqtt:deviceName:switch:binary:property',
+ selector: 'zigbee2mqtt-devicename-switch-binary-property',
+ unit: undefined,
+ };
+
+ expect(result).deep.eq(expectedResult);
+ });
+
+ it(`override min value`, () => {
+ const expose = {
+ type: 'binary',
+ name: 'state',
+ property: 'property',
+ value_min: -1,
+ };
+ const result = buildFeature('deviceName', expose, 'switch');
+
+ const expectedResult = {
+ category: 'switch',
+ type: 'binary',
+ min: -1,
+ max: 1,
+ read_only: true,
+ has_feedback: false,
+ name: 'Property',
+ external_id: 'zigbee2mqtt:deviceName:switch:binary:property',
+ selector: 'zigbee2mqtt-devicename-switch-binary-property',
+ unit: undefined,
+ };
+
+ expect(result).deep.eq(expectedResult);
+ });
+
+ it(`override max value`, () => {
+ const expose = {
+ type: 'binary',
+ name: 'state',
+ property: 'property',
+ value_max: 10,
+ };
+ const result = buildFeature('deviceName', expose, 'switch');
+
+ const expectedResult = {
+ category: 'switch',
+ type: 'binary',
+ min: 0,
+ max: 10,
+ read_only: true,
+ has_feedback: false,
+ name: 'Property',
+ external_id: 'zigbee2mqtt:deviceName:switch:binary:property',
+ selector: 'zigbee2mqtt-devicename-switch-binary-property',
+ unit: undefined,
+ };
+
+ expect(result).deep.eq(expectedResult);
+ });
+
+ it(`override max by values`, () => {
+ const expose = {
+ type: 'binary',
+ name: 'state',
+ property: 'property',
+ values: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9], // length 10
+ };
+ const result = buildFeature('deviceName', expose, 'switch');
+
+ const expectedResult = {
+ category: 'switch',
+ type: 'binary',
+ min: 0,
+ max: 10,
+ read_only: true,
+ has_feedback: false,
+ name: 'Property',
+ external_id: 'zigbee2mqtt:deviceName:switch:binary:property',
+ selector: 'zigbee2mqtt-devicename-switch-binary-property',
+ unit: undefined,
+ };
+
+ expect(result).deep.eq(expectedResult);
+ });
+});
diff --git a/server/test/services/zigbee2mqtt/utils/feature/completeFeature.test.js b/server/test/services/zigbee2mqtt/utils/feature/completeFeature.test.js
new file mode 100644
index 0000000000..aebbb3bea0
--- /dev/null
+++ b/server/test/services/zigbee2mqtt/utils/feature/completeFeature.test.js
@@ -0,0 +1,16 @@
+const { expect } = require('chai');
+
+const { completeFeature } = require('../../../../../services/zigbee2mqtt/utils/features/completeFeature');
+
+describe('zigbee2mqtt completeFeature', () => {
+ it(`completeFeature`, () => {
+ const result = completeFeature('device name', {}, 'property');
+
+ const expected = {
+ name: 'Property',
+ external_id: 'zigbee2mqtt:device name:undefined:undefined:property',
+ selector: 'zigbee2mqtt-device-name-undefined-undefined-property',
+ };
+ expect(result).deep.eq(expected);
+ });
+});
diff --git a/server/test/services/zigbee2mqtt/utils/feature/mapUnit.test.js b/server/test/services/zigbee2mqtt/utils/feature/mapUnit.test.js
new file mode 100644
index 0000000000..e7d2e03d1b
--- /dev/null
+++ b/server/test/services/zigbee2mqtt/utils/feature/mapUnit.test.js
@@ -0,0 +1,31 @@
+const { expect } = require('chai');
+
+const { mapUnit } = require('../../../../../services/zigbee2mqtt/utils/features/mapUnit');
+const { DEVICE_FEATURE_UNITS } = require('../../../../../utils/constants');
+
+describe('zigbee2mqtt mapUnit', () => {
+ const defaultFeatureUnit = 'default';
+
+ const values = [
+ { input: null, expected: defaultFeatureUnit },
+ { input: '%', expected: DEVICE_FEATURE_UNITS.PERCENT },
+ { input: 'hPa', expected: DEVICE_FEATURE_UNITS.HECTO_PASCAL },
+ { input: 'ppm', expected: DEVICE_FEATURE_UNITS.PPM },
+ { input: 'A', expected: DEVICE_FEATURE_UNITS.AMPERE },
+ { input: 'V', expected: DEVICE_FEATURE_UNITS.VOLT },
+ { input: 'mV', expected: DEVICE_FEATURE_UNITS.MILLI_VOLT },
+ { input: 'W', expected: DEVICE_FEATURE_UNITS.WATT },
+ { input: 'kWh', expected: DEVICE_FEATURE_UNITS.KILOWATT_HOUR },
+ { input: '°C', expected: DEVICE_FEATURE_UNITS.CELSIUS },
+ { input: '°F', expected: DEVICE_FEATURE_UNITS.FAHRENHEIT },
+ ];
+
+ values.forEach((value) => {
+ const { input, expected } = value;
+
+ it(`map "${input}" to ${expected}`, () => {
+ const result = mapUnit(input, defaultFeatureUnit);
+ expect(result).eq(expected);
+ });
+ });
+});
diff --git a/server/utils/constants.js b/server/utils/constants.js
index b7057e5834..455c77b6ae 100644
--- a/server/utils/constants.js
+++ b/server/utils/constants.js
@@ -392,6 +392,7 @@ const DEVICE_FEATURE_UNITS = {
KILOWATT: 'kilowatt',
KILOWATT_HOUR: 'kilowatt-hour',
AMPERE: 'ampere',
+ MILLI_VOLT: 'millivolt',
VOLT: 'volt',
PPM: 'ppm',
MM: 'mm',
From 080a02624653931db152aad3ed795440f5066995 Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Sun, 3 Oct 2021 23:17:19 +0200
Subject: [PATCH 3/9] Handle discovered devices
---
front/src/config/i18n/en.json | 1 -
front/src/config/i18n/fr.json | 1 -
.../zigbee2mqtt/discover-page/DiscoverTab.jsx | 9 ------
.../all/zigbee2mqtt/discover-page/actions.js | 28 +++++--------------
.../all/zigbee2mqtt/discover-page/index.js | 1 +
.../zigbee2mqtt/api/zigbee2mqtt.controller.js | 16 +++++------
.../zigbee2mqtt/lib/discoverDevices.js | 15 ----------
.../zigbee2mqtt/lib/getDiscoveredDevices.js | 13 +++++++++
.../zigbee2mqtt/lib/handleMqttMessage.js | 6 ++--
server/services/zigbee2mqtt/lib/index.js | 5 ++--
.../api/zigbee2mqtt.controller.test.js | 10 +++----
.../zigbee2mqtt/lib/discoverDevices.test.js | 27 ------------------
.../lib/getDiscoveredDevices.test.js | 18 ++++++++++++
13 files changed, 58 insertions(+), 92 deletions(-)
delete mode 100644 server/services/zigbee2mqtt/lib/discoverDevices.js
create mode 100644 server/services/zigbee2mqtt/lib/getDiscoveredDevices.js
delete mode 100644 server/test/services/zigbee2mqtt/lib/discoverDevices.test.js
create mode 100644 server/test/services/zigbee2mqtt/lib/getDiscoveredDevices.test.js
diff --git a/front/src/config/i18n/en.json b/front/src/config/i18n/en.json
index acf5805f53..c3e75fae88 100644
--- a/front/src/config/i18n/en.json
+++ b/front/src/config/i18n/en.json
@@ -505,7 +505,6 @@
"device": "({{nbDevices}}) Devices",
"permitJoin": "Permit joining",
"noDeviceDiscovered": "No new device discovered, please click on scan button.",
- "scanButton": "Scan",
"serverNoResponse": "Gladys server is not available.",
"serverNoResponseWebSocker": "Gladys server is not available. Pleash refresh the page.",
"deviceNotHandled": "Device not handled yet, please contact us to help us connect it in Gladys!",
diff --git a/front/src/config/i18n/fr.json b/front/src/config/i18n/fr.json
index 6bc240ca73..9107b74e83 100644
--- a/front/src/config/i18n/fr.json
+++ b/front/src/config/i18n/fr.json
@@ -632,7 +632,6 @@
"device": "({{nbDevices}}) Appareils",
"permitJoin": "Autoriser l'association",
"noDeviceDiscovered": "Aucun nouvel appareil trouvé. Veuillez autoriser l'association des appareils et les appairer.\nATTENTION : Pour la sécurité de votre installation, n'oubliez pas d'interdire l'association après appairage.",
- "scanButton": "Scanner",
"serverNoResponse": "Gladys n'est pas accessible.",
"serverNoResponseWebSocker": "Gladys n'est pas accessible. Veuillez actualiser la page.",
"deviceNotHandled": "L'appareil n'est pas encore géré, veuillez nous contacter pour nous aider à le connecter dans Gladys !",
diff --git a/front/src/routes/integration/all/zigbee2mqtt/discover-page/DiscoverTab.jsx b/front/src/routes/integration/all/zigbee2mqtt/discover-page/DiscoverTab.jsx
index 0b8e0acf15..968c9246ab 100644
--- a/front/src/routes/integration/all/zigbee2mqtt/discover-page/DiscoverTab.jsx
+++ b/front/src/routes/integration/all/zigbee2mqtt/discover-page/DiscoverTab.jsx
@@ -45,15 +45,6 @@ const DiscoverTab = ({ children, ...props }) => (
-
-
-
diff --git a/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js b/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
index fe1bf6f6da..2a49403f6e 100644
--- a/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
+++ b/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
@@ -2,42 +2,28 @@ import update from 'immutability-helper';
import createActionsIntegration from '../../../../../actions/integration';
import createActionsHouse from '../../../../../actions/house';
-let scanTimer;
-
function createActions(store) {
const integrationActions = createActionsIntegration(store);
const houseActions = createActionsHouse(store);
const actions = {
- async discover(state) {
+ async getDiscoveredDevices(state) {
store.setState({
discoverZigbee2mqtt: true,
discoverZigbee2mqttError: null
});
- if (state.session.websocketConnected) {
- try {
- await state.httpClient.post('/api/v1/service/zigbee2mqtt/discover');
- scanTimer = setTimeout(store.setState, 5000, {
- discoverZigbee2mqtt: false,
- discoverZigbee2mqttError: null
- });
- } catch (e) {
- clearTimeout(scanTimer);
- store.setState({
- zigbee2mqttDevices: [],
- discoverZigbee2mqtt: false,
- discoverZigbee2mqttError: 'integration.zigbee2mqtt.discover.serverNoResponse'
- });
- }
- } else {
+
+ try {
+ const { devices: zigbee2mqttDevices } = await state.httpClient.get('/api/v1/service/zigbee2mqtt/devices');
+ store.setState({ zigbee2mqttDevices, discoverZigbee2mqtt: false });
+ } catch (e) {
store.setState({
zigbee2mqttDevices: [],
discoverZigbee2mqtt: false,
- discoverZigbee2mqttError: 'integration.zigbee2mqtt.discover.serverNoResponseWebSocker'
+ discoverZigbee2mqttError: 'integration.zigbee2mqtt.discover.serverNoResponse'
});
}
},
setDiscoveredDevices(state, zigbee2mqttDevices) {
- clearTimeout(scanTimer);
store.setState({
zigbee2mqttDevices,
discoverZigbee2mqtt: false,
diff --git a/front/src/routes/integration/all/zigbee2mqtt/discover-page/index.js b/front/src/routes/integration/all/zigbee2mqtt/discover-page/index.js
index a27d8ffcdc..ca8bf79c95 100644
--- a/front/src/routes/integration/all/zigbee2mqtt/discover-page/index.js
+++ b/front/src/routes/integration/all/zigbee2mqtt/discover-page/index.js
@@ -26,6 +26,7 @@ class Zigbee2mqttIntegration extends Component {
this.props.setDiscoveredDevices(undefined);
this.props.getHouses();
this.props.getIntegrationByName('zigbee2mqtt');
+ this.props.getDiscoveredDevices();
}
componentWillUnmount() {
diff --git a/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js b/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
index ba37cceee2..8f5fbbc0cb 100644
--- a/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
+++ b/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
@@ -3,14 +3,14 @@ const logger = require('../../../utils/logger');
module.exports = function Zigbee2mqttController(gladys, zigbee2mqttManager) {
/**
- * @api {post} /api/v1/service/zigbee2mqtt/discover Launch Zigbee2mqtt devices discovery
- * @apiName discover
+ * @api {get} /api/v1/service/zigbee2mqtt/devices Get discovered Zigbee2mqtt devices
+ * @apiName getDiscoveredDevices
* @apiGroup Zigbee2mqtt
*/
- async function discover(req, res) {
- logger.log('Launching devices discovery');
- await zigbee2mqttManager.discoverDevices();
- res.json({ status: 'discovering' });
+ async function getDiscoveredDevices(req, res) {
+ logger.log('Get discovered devices');
+ const devices = zigbee2mqttManager.getDiscoveredDevices();
+ res.json({ devices });
}
/**
@@ -101,9 +101,9 @@ module.exports = function Zigbee2mqttController(gladys, zigbee2mqttManager) {
}
return {
- 'post /api/v1/service/zigbee2mqtt/discover': {
+ 'get /api/v1/service/zigbee2mqtt/devices': {
authenticated: true,
- controller: asyncMiddleware(discover),
+ controller: asyncMiddleware(getDiscoveredDevices),
},
'get /api/v1/service/zigbee2mqtt/status': {
authenticated: true,
diff --git a/server/services/zigbee2mqtt/lib/discoverDevices.js b/server/services/zigbee2mqtt/lib/discoverDevices.js
deleted file mode 100644
index 8f07c08b61..0000000000
--- a/server/services/zigbee2mqtt/lib/discoverDevices.js
+++ /dev/null
@@ -1,15 +0,0 @@
-const logger = require('../../../utils/logger');
-
-/**
- * @description Publish message on discover topic.
- * @example
- * discoverDevices();
- */
-function discoverDevices() {
- logger.log('Ask for devices enumeration');
- this.mqttClient.publish('zigbee2mqtt/bridge/config/devices/get');
-}
-
-module.exports = {
- discoverDevices,
-};
diff --git a/server/services/zigbee2mqtt/lib/getDiscoveredDevices.js b/server/services/zigbee2mqtt/lib/getDiscoveredDevices.js
new file mode 100644
index 0000000000..8f9d544d6c
--- /dev/null
+++ b/server/services/zigbee2mqtt/lib/getDiscoveredDevices.js
@@ -0,0 +1,13 @@
+/**
+ * @description Get discovered devices.
+ * @returns {Array} Array of discovered devices.
+ * @example
+ * getDiscoveredDevices();
+ */
+function getDiscoveredDevices() {
+ return this.discoveredDevices;
+}
+
+module.exports = {
+ getDiscoveredDevices,
+};
diff --git a/server/services/zigbee2mqtt/lib/handleMqttMessage.js b/server/services/zigbee2mqtt/lib/handleMqttMessage.js
index 0e3a3a51a1..944ca85e8d 100644
--- a/server/services/zigbee2mqtt/lib/handleMqttMessage.js
+++ b/server/services/zigbee2mqtt/lib/handleMqttMessage.js
@@ -4,8 +4,6 @@ const { convertDevice } = require('../utils/convertDevice');
const { convertValue } = require('../utils/convertValue');
const { convertFeature } = require('../utils/convertFeature');
-const TYPE_COORDINATOR = 'Coordinator';
-
/**
* @description Handle a new message receive in MQTT.
* @param {string} topic - MQTT topic.
@@ -26,7 +24,7 @@ function handleMqttMessage(topic, message) {
const devices = JSON.parse(message);
const convertedDevices = devices
// Remove Coordinator
- .filter((d) => d.type !== TYPE_COORDINATOR)
+ .filter((d) => d.supported)
// Remove existing devices
.filter((d) => {
const existingDevice = this.gladys.stateManager.get('deviceByExternalId', `zigbee2mqtt:${d.friendly_name}`);
@@ -38,6 +36,8 @@ function handleMqttMessage(topic, message) {
// Add features
.map((d) => convertDevice(d, this.serviceId));
+ this.discoveredDevices = convertedDevices;
+
this.gladys.event.emit(EVENTS.WEBSOCKET.SEND_ALL, {
type: WEBSOCKET_MESSAGE_TYPES.ZIGBEE2MQTT.DISCOVER,
payload: convertedDevices,
diff --git a/server/services/zigbee2mqtt/lib/index.js b/server/services/zigbee2mqtt/lib/index.js
index 8ff2c5a88e..329820060a 100644
--- a/server/services/zigbee2mqtt/lib/index.js
+++ b/server/services/zigbee2mqtt/lib/index.js
@@ -3,7 +3,7 @@ const { connect } = require('./connect');
const { getConfiguration } = require('./getConfiguration');
const { disconnect } = require('./disconnect');
const { handleMqttMessage } = require('./handleMqttMessage');
-const { discoverDevices } = require('./discoverDevices');
+const { getDiscoveredDevices } = require('./getDiscoveredDevices');
const { setValue } = require('./setValue');
const { status } = require('./status');
const { subscribe } = require('./subscribe');
@@ -27,6 +27,7 @@ const Zigbee2mqttManager = function Zigbee2mqttManager(gladys, mqttLibrary, serv
this.serviceId = serviceId;
this.mqttClient = null;
+ this.discoveredDevices = [];
this.topicBinds = {};
this.usbConfigured = false;
this.mqttExist = false;
@@ -48,7 +49,7 @@ Zigbee2mqttManager.prototype.getConfiguration = getConfiguration;
Zigbee2mqttManager.prototype.basePath = basePath;
Zigbee2mqttManager.prototype.disconnect = disconnect;
Zigbee2mqttManager.prototype.handleMqttMessage = handleMqttMessage;
-Zigbee2mqttManager.prototype.discoverDevices = discoverDevices;
+Zigbee2mqttManager.prototype.getDiscoveredDevices = getDiscoveredDevices;
Zigbee2mqttManager.prototype.setValue = setValue;
Zigbee2mqttManager.prototype.status = status;
Zigbee2mqttManager.prototype.subscribe = subscribe;
diff --git a/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js b/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
index 62efc2ff97..c49a886711 100644
--- a/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
+++ b/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
@@ -11,7 +11,7 @@ const gladys = {
event,
};
const zigbee2mqttManager = {
- discoverDevices: fake.resolves(true),
+ getDiscoveredDevices: fake.returns(['device']),
status: fake.returns(true),
init: fake.returns(true),
installMqttContainer: fake.returns(true),
@@ -29,16 +29,16 @@ describe('zigbee2mqtt API', () => {
sinon.reset();
});
- it('post /api/v1/service/zigbee2mqtt/discover', async () => {
+ it('get /api/v1/service/zigbee2mqtt/devices', async () => {
const req = {};
const res = {
json: fake.returns(null),
};
- await controller['post /api/v1/service/zigbee2mqtt/discover'].controller(req, res);
+ await controller['get /api/v1/service/zigbee2mqtt/devices'].controller(req, res);
- assert.calledOnce(zigbee2mqttManager.discoverDevices);
- assert.calledWith(res.json, { status: 'discovering' });
+ assert.calledOnce(zigbee2mqttManager.getDiscoveredDevices);
+ assert.calledWith(res.json, { devices: ['device'] });
});
it('get /api/v1/service/zigbee2mqtt/status', async () => {
diff --git a/server/test/services/zigbee2mqtt/lib/discoverDevices.test.js b/server/test/services/zigbee2mqtt/lib/discoverDevices.test.js
deleted file mode 100644
index 9851e06db1..0000000000
--- a/server/test/services/zigbee2mqtt/lib/discoverDevices.test.js
+++ /dev/null
@@ -1,27 +0,0 @@
-const sinon = require('sinon');
-
-const { assert, fake } = sinon;
-const proxyquire = require('proxyquire').noCallThru();
-
-const Zigbee2MqttService = proxyquire('../../../../services/zigbee2mqtt', {});
-
-const gladys = {};
-
-const serviceId = 'f87b7af2-ca8e-44fc-b754-444354b42fee';
-
-const mqtt = {
- publish: fake.resolves(true),
-};
-
-describe('zigbee2mqtt discoverDevices', () => {
- // PREPARE
- const zigbee2MqttService = Zigbee2MqttService(gladys, serviceId);
- zigbee2MqttService.device.mqttClient = mqtt;
-
- it('discover devices', async () => {
- // EXECUTE
- await zigbee2MqttService.device.discoverDevices();
- // ASSERT
- assert.calledWith(mqtt.publish, 'zigbee2mqtt/bridge/config/devices/get');
- });
-});
diff --git a/server/test/services/zigbee2mqtt/lib/getDiscoveredDevices.test.js b/server/test/services/zigbee2mqtt/lib/getDiscoveredDevices.test.js
new file mode 100644
index 0000000000..c338c4f256
--- /dev/null
+++ b/server/test/services/zigbee2mqtt/lib/getDiscoveredDevices.test.js
@@ -0,0 +1,18 @@
+const { expect } = require('chai');
+
+const Zigbee2MqttService = require('../../../../services/zigbee2mqtt');
+
+const gladys = {};
+const serviceId = 'f87b7af2-ca8e-44fc-b754-444354b42fee';
+
+describe('zigbee2mqtt getDiscoveredDevices', () => {
+ // PREPARE
+ const zigbee2MqttService = Zigbee2MqttService(gladys, serviceId);
+
+ it('get discovered devices', async () => {
+ // EXECUTE
+ const devices = zigbee2MqttService.device.getDiscoveredDevices();
+ // ASSERT
+ expect(devices).deep.eq([]);
+ });
+});
From 49d76fdd2688dd0a9910ebe1901ce19eba917882 Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Mon, 18 Oct 2021 21:39:07 +0200
Subject: [PATCH 4/9] Fix review comments
---
.../all/zigbee2mqtt/discover-page/actions.js | 2 +-
.../zigbee2mqtt/api/zigbee2mqtt.controller.js | 6 +--
.../zigbee2mqtt/exposes/binaryType.js | 20 ---------
.../services/zigbee2mqtt/exposes/enumType.js | 22 ----------
.../zigbee2mqtt/exposes/numericType.js | 41 +------------------
.../zigbee2mqtt/utils/convertDevice.js | 1 -
.../api/zigbee2mqtt.controller.test.js | 6 +--
7 files changed, 9 insertions(+), 89 deletions(-)
diff --git a/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js b/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
index 2a49403f6e..79859ca114 100644
--- a/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
+++ b/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
@@ -13,7 +13,7 @@ function createActions(store) {
});
try {
- const { devices: zigbee2mqttDevices } = await state.httpClient.get('/api/v1/service/zigbee2mqtt/devices');
+ const zigbee2mqttDevices = await state.httpClient.get('/api/v1/service/zigbee2mqtt/device');
store.setState({ zigbee2mqttDevices, discoverZigbee2mqtt: false });
} catch (e) {
store.setState({
diff --git a/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js b/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
index 8f5fbbc0cb..31a1e85915 100644
--- a/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
+++ b/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
@@ -3,14 +3,14 @@ const logger = require('../../../utils/logger');
module.exports = function Zigbee2mqttController(gladys, zigbee2mqttManager) {
/**
- * @api {get} /api/v1/service/zigbee2mqtt/devices Get discovered Zigbee2mqtt devices
+ * @api {get} /api/v1/service/zigbee2mqtt/device Get discovered Zigbee2mqtt devices
* @apiName getDiscoveredDevices
* @apiGroup Zigbee2mqtt
*/
async function getDiscoveredDevices(req, res) {
logger.log('Get discovered devices');
const devices = zigbee2mqttManager.getDiscoveredDevices();
- res.json({ devices });
+ res.json(devices);
}
/**
@@ -101,7 +101,7 @@ module.exports = function Zigbee2mqttController(gladys, zigbee2mqttManager) {
}
return {
- 'get /api/v1/service/zigbee2mqtt/devices': {
+ 'get /api/v1/service/zigbee2mqtt/device': {
authenticated: true,
controller: asyncMiddleware(getDiscoveredDevices),
},
diff --git a/server/services/zigbee2mqtt/exposes/binaryType.js b/server/services/zigbee2mqtt/exposes/binaryType.js
index 949c97db1a..df9d9dd7f6 100644
--- a/server/services/zigbee2mqtt/exposes/binaryType.js
+++ b/server/services/zigbee2mqtt/exposes/binaryType.js
@@ -9,26 +9,6 @@ module.exports = {
max: 1,
},
names: {
- /*
- auto_lock: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.SWITCH,
- type: DEVICE_FEATURE_TYPES.SENSOR.BINARY,
- },
- },
- away_mode: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.FAN,
- type: DEVICE_FEATURE_TYPES.FAN.BINARY,
- },
- },
- carbon_monoxide: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.MONOXIDE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- },
- },
- */
contact: {
feature: {
category: DEVICE_FEATURE_CATEGORIES.OPENING_SENSOR,
diff --git a/server/services/zigbee2mqtt/exposes/enumType.js b/server/services/zigbee2mqtt/exposes/enumType.js
index 1ddf759394..0cd27aef48 100644
--- a/server/services/zigbee2mqtt/exposes/enumType.js
+++ b/server/services/zigbee2mqtt/exposes/enumType.js
@@ -13,27 +13,5 @@ module.exports = {
type: DEVICE_FEATURE_TYPES.BUTTON.CLICK,
},
},
- /*
- fan_mode: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.FAN,
- type: DEVICE_FEATURE_TYPES.FAN.SPEED,
- },
- },
- state: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.CURTAIN,
- type: DEVICE_FEATURE_TYPES.CURTAIN.STATE,
- min: 0,
- max: 2,
- },
- }
- system_mode: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.FAN,
- type: DEVICE_FEATURE_TYPES.FAN.MODE,
- },
- },
- */
},
};
diff --git a/server/services/zigbee2mqtt/exposes/numericType.js b/server/services/zigbee2mqtt/exposes/numericType.js
index 7d0b0e07dc..5212593530 100644
--- a/server/services/zigbee2mqtt/exposes/numericType.js
+++ b/server/services/zigbee2mqtt/exposes/numericType.js
@@ -41,12 +41,6 @@ module.exports = {
max: 500,
},
},
- /*
- confort_temperature: {
- feature: {
- },
- },
- */
current: {
feature: {
category: DEVICE_FEATURE_CATEGORIES.SWITCH,
@@ -76,7 +70,7 @@ module.exports = {
},
cpu_temperature: {
feature: {
- category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
+ category: DEVICE_FEATURE_CATEGORIES.DEVICE_TEMPERATURE_SENSOR,
type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
unit: DEVICE_FEATURE_UNITS.CELSIUS,
min: -100,
@@ -85,7 +79,7 @@ module.exports = {
},
device_temperature: {
feature: {
- category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
+ category: DEVICE_FEATURE_CATEGORIES.DEVICE_TEMPERATURE_SENSOR,
type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
unit: DEVICE_FEATURE_UNITS.CELSIUS,
min: -100,
@@ -118,16 +112,6 @@ module.exports = {
type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
},
},
- /*
- hue: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT,
- type: DEVICE_FEATURE_TYPES.LIGHT.HUE,
- min: 150?,
- max: 500?,
- },
- },
- */
humidity: {
feature: {
category: DEVICE_FEATURE_CATEGORIES.HUMIDITY_SENSOR,
@@ -163,17 +147,6 @@ module.exports = {
max: 150,
},
},
- /*
- position: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.CURTAIN,
- type: DEVICE_FEATURE_TYPES.CURTAIN.POSITION,
- unit: DEVICE_FEATURE_UNITS.PERCENT,
- min: 0,
- max: 100,
- },
- },
- */
power: {
feature: {
category: DEVICE_FEATURE_CATEGORIES.SWITCH,
@@ -188,16 +161,6 @@ module.exports = {
unit: DEVICE_FEATURE_UNITS.HECTO_PASCAL,
},
},
- /*
- saturation: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.LIGHT,
- type: DEVICE_FEATURE_TYPES.LIGHT.SATURATION,
- min: 150?,
- max: 500?,
- },
- },
- */
temperature: {
feature: {
category: DEVICE_FEATURE_CATEGORIES.TEMPERATURE_SENSOR,
diff --git a/server/services/zigbee2mqtt/utils/convertDevice.js b/server/services/zigbee2mqtt/utils/convertDevice.js
index 7f3afe0836..375c1da7d4 100644
--- a/server/services/zigbee2mqtt/utils/convertDevice.js
+++ b/server/services/zigbee2mqtt/utils/convertDevice.js
@@ -29,7 +29,6 @@ function convertDevice(device, serviceId) {
};
logger.debug(`Device ${name} / model ${model} ${supported ? '' : 'NOT'} managed by Gladys`);
- logger.debug(gladysDevice);
return gladysDevice;
}
diff --git a/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js b/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
index c49a886711..8397994f81 100644
--- a/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
+++ b/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
@@ -29,16 +29,16 @@ describe('zigbee2mqtt API', () => {
sinon.reset();
});
- it('get /api/v1/service/zigbee2mqtt/devices', async () => {
+ it('get /api/v1/service/zigbee2mqtt/device', async () => {
const req = {};
const res = {
json: fake.returns(null),
};
- await controller['get /api/v1/service/zigbee2mqtt/devices'].controller(req, res);
+ await controller['get /api/v1/service/zigbee2mqtt/device'].controller(req, res);
assert.calledOnce(zigbee2mqttManager.getDiscoveredDevices);
- assert.calledWith(res.json, { devices: ['device'] });
+ assert.calledWith(res.json, ['device']);
});
it('get /api/v1/service/zigbee2mqtt/status', async () => {
From f7fd24896508c3adb666745af16d5b039f74135e Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Thu, 21 Oct 2021 20:59:36 +0200
Subject: [PATCH 5/9] Load composite type
---
server/services/zigbee2mqtt/exposes/index.js | 2 ++
1 file changed, 2 insertions(+)
diff --git a/server/services/zigbee2mqtt/exposes/index.js b/server/services/zigbee2mqtt/exposes/index.js
index 6e5e303293..47088da97b 100644
--- a/server/services/zigbee2mqtt/exposes/index.js
+++ b/server/services/zigbee2mqtt/exposes/index.js
@@ -1,9 +1,11 @@
const binaryType = require('./binaryType');
const numericType = require('./numericType');
const enumType = require('./enumType');
+const compositeType = require('./compositeType');
module.exports = {
[binaryType.type]: binaryType,
[numericType.type]: numericType,
[enumType.type]: enumType,
+ [compositeType.type]: compositeType,
};
From e3d90bdbebbd6174c84eefef44452ecdd23d3426 Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Thu, 21 Oct 2021 21:04:41 +0200
Subject: [PATCH 6/9] Illuminance max value
---
server/services/zigbee2mqtt/exposes/numericType.js | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/server/services/zigbee2mqtt/exposes/numericType.js b/server/services/zigbee2mqtt/exposes/numericType.js
index 5212593530..ce2cd9b9bd 100644
--- a/server/services/zigbee2mqtt/exposes/numericType.js
+++ b/server/services/zigbee2mqtt/exposes/numericType.js
@@ -126,7 +126,7 @@ module.exports = {
category: DEVICE_FEATURE_CATEGORIES.LIGHT_SENSOR,
type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
min: 0,
- max: 10000,
+ max: 100000,
},
},
illuminance_lux: {
@@ -135,7 +135,7 @@ module.exports = {
type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
unit: DEVICE_FEATURE_UNITS.LUX,
min: 0,
- max: 10000,
+ max: 100000,
},
},
local_temperature: {
From 0e2cfdfc28c9a6cf58ee568f1a7a5b3342daf45b Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Sat, 23 Oct 2021 08:21:27 +0200
Subject: [PATCH 7/9] Force composite color as actuator
---
server/services/zigbee2mqtt/exposes/compositeType.js | 2 ++
1 file changed, 2 insertions(+)
diff --git a/server/services/zigbee2mqtt/exposes/compositeType.js b/server/services/zigbee2mqtt/exposes/compositeType.js
index 2db3ea9adc..82bc42b1f7 100644
--- a/server/services/zigbee2mqtt/exposes/compositeType.js
+++ b/server/services/zigbee2mqtt/exposes/compositeType.js
@@ -7,6 +7,8 @@ module.exports = {
feature: {
category: DEVICE_FEATURE_CATEGORIES.LIGHT,
type: DEVICE_FEATURE_TYPES.LIGHT.COLOR,
+ has_feedback: true,
+ read_only: false,
min: 0,
max: 16777215,
},
From ce829792acdb63384d926d0654973cf61f6e3b50 Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Sun, 24 Oct 2021 09:12:19 +0200
Subject: [PATCH 8/9] Fix zigbee2mqtt discovered path
---
front/src/config/demo.json | 2175 +++++++++++++++++
.../all/zigbee2mqtt/discover-page/actions.js | 2 +-
.../zigbee2mqtt/api/zigbee2mqtt.controller.js | 4 +-
.../api/zigbee2mqtt.controller.test.js | 4 +-
4 files changed, 2180 insertions(+), 5 deletions(-)
create mode 100644 front/src/config/demo.json
diff --git a/front/src/config/demo.json b/front/src/config/demo.json
new file mode 100644
index 0000000000..0273dfff32
--- /dev/null
+++ b/front/src/config/demo.json
@@ -0,0 +1,2175 @@
+{
+ "post /api/v1/login": {
+ "id": "215811c9-c0aa-4148-8a4b-e02892d7446f",
+ "firstname": "tony",
+ "lastname": "Stark",
+ "email": "tony.stark@gladysassistant.com",
+ "language": "en",
+ "birthdate": "2011-02-04",
+ "role": "admin",
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z",
+ "refresh_token": "15535ed55088d46b9a01738bfb2b96f982fb16edb2a5241d078775a7db8aa38a8ae59e73f81aa5367b62b1daef8aea5e3b7de4ff66dc8fb00f6ed02b6c3eb14ac68b1716e9cdb9425f88bf2eeb5b8cc3b4eb66913bbd8e5084381dc22fe1ff092c0efd80f2ec766511f03121bdffcc02202a20d5916e6e58c6aed4a84fb9980a99b828c8ded74d17e3c91108f7e50dccb80281720b6b37fe26345371cd2b4a1134abfbc63689814375aee968af15dc24379c7c95200c0c1740817806abfca934ccb4fb183e4c95e19f55a2e4c8a3bb453cf0700a6f7baa7088b24297d212f2ccfc3586093c28e731e9909addbead2b9c095f1a7f8993f4ddd405",
+ "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiOTJiZjk0NDEtYzljMC00YTVmLWI3YmItNGY3NmYwZWM0Yzk1Iiwic2NvcGUiOlsiZGFzaGJvYXJkOndyaXRlIiwiZGFzaGJvYXJkOnJlYWQiXSwic2Vzc2lvbl9pZCI6IjZhOTYyNzk2LTZlMGQtNDRiNC04Y2Y2LWRkMmJhYjhjY2M0ZiIsImlhdCI6MTU1MTA2NzM5MywiZXhwIjoxNTUxMTUzNzkzLCJhdWQiOiJ1c2VyIiwiaXNzIjoiZ2xhZHlzIn0.JfiRsTn4cyARIMElD5DgyFt7xKHPcTNnaMLKznbfVc4"
+ },
+ "get /api/v1/me": {
+ "id": "215811c9-c0aa-4148-8a4b-e02892d7446f",
+ "firstname": "Tony",
+ "lastname": "Stark",
+ "selector": "tony",
+ "email": "tony.stark@gladysassistant.com",
+ "language": "en",
+ "birthdate": "2011-02-04",
+ "role": "admin",
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z",
+ "refresh_token": "15535ed55088d46b9a01738bfb2b96f982fb16edb2a5241d078775a7db8aa38a8ae59e73f81aa5367b62b1daef8aea5e3b7de4ff66dc8fb00f6ed02b6c3eb14ac68b1716e9cdb9425f88bf2eeb5b8cc3b4eb66913bbd8e5084381dc22fe1ff092c0efd80f2ec766511f03121bdffcc02202a20d5916e6e58c6aed4a84fb9980a99b828c8ded74d17e3c91108f7e50dccb80281720b6b37fe26345371cd2b4a1134abfbc63689814375aee968af15dc24379c7c95200c0c1740817806abfca934ccb4fb183e4c95e19f55a2e4c8a3bb453cf0700a6f7baa7088b24297d212f2ccfc3586093c28e731e9909addbead2b9c095f1a7f8993f4ddd405",
+ "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiOTJiZjk0NDEtYzljMC00YTVmLWI3YmItNGY3NmYwZWM0Yzk1Iiwic2NvcGUiOlsiZGFzaGJvYXJkOndyaXRlIiwiZGFzaGJvYXJkOnJlYWQiXSwic2Vzc2lvbl9pZCI6IjZhOTYyNzk2LTZlMGQtNDRiNC04Y2Y2LWRkMmJhYjhjY2M0ZiIsImlhdCI6MTU1MTA2NzM5MywiZXhwIjoxNTUxMTUzNzkzLCJhdWQiOiJ1c2VyIiwiaXNzIjoiZ2xhZHlzIn0.JfiRsTn4cyARIMElD5DgyFt7xKHPcTNnaMLKznbfVc4"
+ },
+ "get /api/v1/me/picture": "",
+ "get /api/v1/user?fields=id,firstname,selector,picture,last_latitude,last_longitude,last_altitude,last_accuracy,last_location_changed": [
+ {
+ "firstname": "Tony",
+ "last_latitude": 41.93425385676557,
+ "last_longitude": 12.402756238310928,
+ "picture": ""
+ }
+ ],
+ "post /api/v1/access-token": {
+ "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiOTJiZjk0NDEtYzljMC00YTVmLWI3YmItNGY3NmYwZWM0Yzk1Iiwic2NvcGUiOlsiZGFzaGJvYXJkOndyaXRlIiwiZGFzaGJvYXJkOnJlYWQiXSwic2Vzc2lvbl9pZCI6IjZhOTYyNzk2LTZlMGQtNDRiNC04Y2Y2LWRkMmJhYjhjY2M0ZiIsImlhdCI6MTU1MTA2NzM5MywiZXhwIjoxNTUxMTUzNzkzLCJhdWQiOiJ1c2VyIiwiaXNzIjoiZ2xhZHlzIn0.JfiRsTn4cyARIMElD5DgyFt7xKHPcTNnaMLKznbfVc4"
+ },
+ "post /api/v1/user": {
+ "id": "215811c9-c0aa-4148-8a4b-e02892d7446f",
+ "firstname": "tony",
+ "lastname": "Stark",
+ "email": "tony.stark@gladysassistant.com",
+ "language": "en",
+ "birthdate": "2011-02-04",
+ "role": "admin",
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z",
+ "refresh_token": "15535ed55088d46b9a01738bfb2b96f982fb16edb2a5241d078775a7db8aa38a8ae59e73f81aa5367b62b1daef8aea5e3b7de4ff66dc8fb00f6ed02b6c3eb14ac68b1716e9cdb9425f88bf2eeb5b8cc3b4eb66913bbd8e5084381dc22fe1ff092c0efd80f2ec766511f03121bdffcc02202a20d5916e6e58c6aed4a84fb9980a99b828c8ded74d17e3c91108f7e50dccb80281720b6b37fe26345371cd2b4a1134abfbc63689814375aee968af15dc24379c7c95200c0c1740817806abfca934ccb4fb183e4c95e19f55a2e4c8a3bb453cf0700a6f7baa7088b24297d212f2ccfc3586093c28e731e9909addbead2b9c095f1a7f8993f4ddd405",
+ "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiOTJiZjk0NDEtYzljMC00YTVmLWI3YmItNGY3NmYwZWM0Yzk1Iiwic2NvcGUiOlsiZGFzaGJvYXJkOndyaXRlIiwiZGFzaGJvYXJkOnJlYWQiXSwic2Vzc2lvbl9pZCI6IjZhOTYyNzk2LTZlMGQtNDRiNC04Y2Y2LWRkMmJhYjhjY2M0ZiIsImlhdCI6MTU1MTA2NzM5MywiZXhwIjoxNTUxMTUzNzkzLCJhdWQiOiJ1c2VyIiwiaXNzIjoiZ2xhZHlzIn0.JfiRsTn4cyARIMElD5DgyFt7xKHPcTNnaMLKznbfVc4"
+ },
+ "patch /api/v1/user": {
+ "id": "215811c9-c0aa-4148-8a4b-e02892d7446f",
+ "firstname": "tony",
+ "lastname": "Stark",
+ "email": "tony.stark@gladysassistant.com",
+ "language": "en",
+ "birthdate": "2011-02-04",
+ "role": "admin",
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z",
+ "refresh_token": "15535ed55088d46b9a01738bfb2b96f982fb16edb2a5241d078775a7db8aa38a8ae59e73f81aa5367b62b1daef8aea5e3b7de4ff66dc8fb00f6ed02b6c3eb14ac68b1716e9cdb9425f88bf2eeb5b8cc3b4eb66913bbd8e5084381dc22fe1ff092c0efd80f2ec766511f03121bdffcc02202a20d5916e6e58c6aed4a84fb9980a99b828c8ded74d17e3c91108f7e50dccb80281720b6b37fe26345371cd2b4a1134abfbc63689814375aee968af15dc24379c7c95200c0c1740817806abfca934ccb4fb183e4c95e19f55a2e4c8a3bb453cf0700a6f7baa7088b24297d212f2ccfc3586093c28e731e9909addbead2b9c095f1a7f8993f4ddd405",
+ "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoiOTJiZjk0NDEtYzljMC00YTVmLWI3YmItNGY3NmYwZWM0Yzk1Iiwic2NvcGUiOlsiZGFzaGJvYXJkOndyaXRlIiwiZGFzaGJvYXJkOnJlYWQiXSwic2Vzc2lvbl9pZCI6IjZhOTYyNzk2LTZlMGQtNDRiNC04Y2Y2LWRkMmJhYjhjY2M0ZiIsImlhdCI6MTU1MTA2NzM5MywiZXhwIjoxNTUxMTUzNzkzLCJhdWQiOiJ1c2VyIiwiaXNzIjoiZ2xhZHlzIn0.JfiRsTn4cyARIMElD5DgyFt7xKHPcTNnaMLKznbfVc4"
+ },
+ "get /api/v1/user?fields=firstname,lastname,role,selector,picture,current_house_id,last_house_changed": [
+ {
+ "firstname": "Tony",
+ "lastname": "Stark",
+ "role": "admin",
+ "selector": "tony",
+ "picture": "",
+ "current_house_id": "8fe7acf2-f27b-46d4-9f8e-c871ab1e6780",
+ "last_house_changed": "2021-07-12T07:22:19.014Z"
+ },
+ {
+ "firstname": "Pepper",
+ "lastname": "Pots",
+ "role": "admin",
+ "selector": "pepper",
+ "picture": "",
+ "current_house_id": "",
+ "last_house_changed": "2021-07-12T07:22:19.014Z"
+ }
+ ],
+ "get /api/v1/dashboard": [
+ {
+ "id": "329897d2-0620-458c-addf-4009ff5bc205",
+ "name": "Home",
+ "type": "main",
+ "selector": "home"
+ }
+ ],
+ "get /api/v1/dashboard/home": {
+ "id": "329897d2-0620-458c-addf-4009ff5bc205",
+ "name": "Home",
+ "type": "main",
+ "selector": "home",
+ "boxes": [
+ [
+ {
+ "type": "weather",
+ "house": "main-house"
+ },
+ {
+ "type": "camera",
+ "camera": "living-room-camera",
+ "name": "Garden"
+ }
+ ],
+ [
+ {
+ "type": "temperature-in-room",
+ "room": "living-room"
+ },
+ {
+ "type": "devices-in-room",
+ "room": "living-room",
+ "device_features": [
+ "main-lamp-binary",
+ "tv-lamp-binary",
+ "tv-lamp-color",
+ "tv-lamp-brightness",
+ "mqtt-living-room-switch",
+ "mqtt-living-room-dimmer",
+ "mqtt-living-room-temp"
+ ]
+ }
+ ],
+ [
+ {
+ "type": "devices-in-room",
+ "room": "kitchen",
+ "device_features": ["main-presence-sensor"]
+ },
+ {
+ "type": "user-presence"
+ }
+ ]
+ ],
+ "created_at": "2019-05-15T08:48:20.275Z",
+ "updated_at": "2019-05-16T06:29:44.767Z"
+ },
+ "patch /api/v1/dashboard/home": {
+ "id": "329897d2-0620-458c-addf-4009ff5bc205",
+ "name": "Home",
+ "type": "main",
+ "selector": "home",
+ "boxes": [
+ [
+ {
+ "type": "weather",
+ "house": "main-house"
+ },
+ {
+ "type": "camera",
+ "camera": "living-room-camera",
+ "name": "Garden"
+ }
+ ],
+ [
+ {
+ "type": "temperature-in-room",
+ "room": "living-room"
+ },
+ {
+ "type": "user-presence"
+ },
+ {
+ "type": "devices-in-room",
+ "room": "living-room"
+ }
+ ],
+ [
+ {
+ "type": "devices-in-room",
+ "room": "kitchen"
+ }
+ ]
+ ],
+ "created_at": "2019-05-15T08:48:20.275Z",
+ "updated_at": "2019-05-16T06:29:44.767Z"
+ },
+ "get /api/v1/house/main-house/weather": {
+ "temperature": 27.9,
+ "humidity": 0.99,
+ "pressure": 1005.09,
+ "datetime": "2019-05-09T04:27:57.000Z",
+ "units": "metric",
+ "wind_speed": 1.96,
+ "weather": "rain",
+ "house": {
+ "id": "6a29f33b-e5c9-4b08-9d3f-ced2cab80a87",
+ "name": "Main house",
+ "selector": "main-house",
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z"
+ },
+ "options": {
+ "latitude": 12,
+ "longitude": 12,
+ "language": "en"
+ },
+ "hours": [
+ {
+ "temperature": 27.9,
+ "humidity": 0.99,
+ "pressure": 1005.09,
+ "datetime": "2019-05-09T04:27:57.000Z",
+ "units": "metric",
+ "wind_speed": 1.96,
+ "wind_direction": 1.96,
+ "weather": "rain"
+ }
+ ],
+ "days": [
+ {
+ "temperature_min": 20.9,
+ "temperature_max": 27.9,
+ "humidity": 0.99,
+ "pressure": 1005.09,
+ "datetime": "2019-05-09T04:27:57.000Z",
+ "units": "metric",
+ "wind_speed": 1.96,
+ "wind_direction": 1.96,
+ "weather": "rain"
+ }
+ ]
+ },
+ "get /api/v1/room/living-room?expand=temperature": {
+ "id": "1c634ff4-0476-4733-a084-b4a43d649c84",
+ "name": "Living Room",
+ "selector": "living-room",
+ "temperature": {
+ "temperature": 26.5,
+ "unit": "celsius"
+ }
+ },
+ "get /api/v1/camera/living-room-camera/image": "",
+ "get /api/v1/room/living-room?expand=devices": {
+ "id": "1c634ff4-0476-4733-a084-b4a43d649c84",
+ "name": "Living Room",
+ "selector": "living-room",
+ "devices": [
+ {
+ "id": "b32daa9a-8f77-4394-b4f3-ffea215062d2",
+ "name": "Main Lamp",
+ "selector": "main-lamp",
+ "features": [
+ {
+ "name": "Main Lamp",
+ "selector": "main-lamp-binary",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 1,
+ "read_only": false,
+ "last_value": 1,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "TV Lamp color",
+ "selector": "tv-lamp-color",
+ "category": "light",
+ "type": "color",
+ "min": 0,
+ "max": 16777215,
+ "read_only": false,
+ "last_value": 65000,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "TV Lamp brightness",
+ "selector": "tv-lamp-brightness",
+ "category": "light",
+ "type": "brightness",
+ "min": 0,
+ "max": 100,
+ "read_only": false,
+ "last_value": 55,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ },
+ {
+ "id": "b32daa9a-8f77-4394-b4f3-ffea215062d2",
+ "name": "TV Lamp",
+ "selector": "tv-lamp",
+ "features": [
+ {
+ "name": "TV Lamp feature",
+ "selector": "tv-lamp-binary",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 1,
+ "read_only": false,
+ "last_value": 1,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ },
+ {
+ "id": "adefb484-223e-478a-8330-8fb1b3a20920",
+ "selector": "temperature-living-room",
+ "features": [
+ {
+ "name": "Temperature",
+ "selector": "temperature-living-room-celsius",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "unit": "celsius",
+ "min": -200,
+ "max": 200,
+ "read_only": true,
+ "last_value": 27,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ },
+ {
+ "id": "81d637d2-b7f5-4cc3-a39e-2270fd069ee2",
+ "selector": "mqtt-living-room",
+ "name": "MQTT device",
+ "service": {
+ "name": "mqtt"
+ },
+ "features": [
+ {
+ "name": "Window Temp",
+ "selector": "mqtt-living-room-temp",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "unit": "celsius",
+ "min": -200,
+ "max": 200,
+ "read_only": true,
+ "last_value": 27,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ }
+ ]
+ },
+ "get /api/v1/room/kitchen?expand=devices": {
+ "id": "be6ba391-ebb3-472d-81af-d75d710a8430",
+ "name": "Kitchen",
+ "selector": "kitchen",
+ "devices": [
+ {
+ "id": "adefb484-223e-478a-8330-8fb1b3a20920",
+ "selector": "sensor-kitchen",
+ "features": [
+ {
+ "name": "Temperature",
+ "selector": "temperature-living-room-celsius",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "unit": "celsius",
+ "min": -200,
+ "max": 200,
+ "read_only": true,
+ "last_value": 30,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "Humidity",
+ "selector": "temperature-living-room-celsius",
+ "category": "humidity-sensor",
+ "type": "decimal",
+ "unit": "percent",
+ "min": -200,
+ "max": 200,
+ "read_only": true,
+ "last_value": 70,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "Co2",
+ "selector": "co2-kitchen",
+ "category": "co2-sensor",
+ "type": "decimal",
+ "unit": "ppm",
+ "min": 0,
+ "max": 5000,
+ "read_only": true,
+ "last_value": 340,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "Presence",
+ "selector": "main-presence-sensor",
+ "category": "presence-sensor",
+ "type": "push",
+ "unit": null,
+ "min": 0,
+ "max": 1,
+ "read_only": true,
+ "last_value": 0,
+ "last_value_changed": "2021-07-13 13:49:07.556 +01:00"
+ },
+ {
+ "name": "Kitchen door",
+ "selector": "temperature-living-room-celsius",
+ "category": "opening-sensor",
+ "type": "binary",
+ "unit": null,
+ "min": -200,
+ "max": 200,
+ "read_only": true,
+ "last_value": 0,
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ }
+ ]
+ },
+ "post /api/v1/variable/DEVICE_STATE_HISTORY_IN_DAYS": {
+ "id": "18da1930-abe9-4c99-ab9c-7ddd61aef692",
+ "name": "DEVICE_STATE_HISTORY_IN_DAYS",
+ "value": 90,
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z"
+ },
+ "post /api/v1/house": {
+ "id": "6a29f33b-e5c9-4b08-9d3f-ced2cab80a87",
+ "name": "My House",
+ "selector": "my-house",
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z"
+ },
+ "post /api/v1/house/my-house/room": {
+ "id": "1bdc3614-6082-43c3-9e4a-3b00781013a4",
+ "name": "My room",
+ "house_id": "6a29f33b-e5c9-4b08-9d3f-ced2cab80a87",
+ "created_at": "2019-02-20T04:26:47.811Z",
+ "updated_at": "2019-02-20T04:26:47.811Z"
+ },
+ "get /api/v1/room?expand=devices": [
+ {
+ "id": "1c634ff4-0476-4733-a084-b4a43d649c84",
+ "name": "Living Room",
+ "selector": "living-room",
+ "devices": [
+ {
+ "id": "b32daa9a-8f77-4394-b4f3-ffea215062d2",
+ "name": "Multi-sensor",
+ "selector": "sensors",
+ "features": [
+ {
+ "name": "Temperature",
+ "selector": "temperature-sensor",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "min": -20,
+ "max": 255,
+ "read_only": true,
+ "last_value": 25,
+ "unit": "celsius",
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "Humidity",
+ "selector": "humidity-sensor",
+ "category": "humidity-sensor",
+ "type": "decimal",
+ "min": 0,
+ "max": 100,
+ "read_only": true,
+ "last_value": 56,
+ "unit": "percent",
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "Co2",
+ "selector": "co2-sensor",
+ "category": "co2-sensor",
+ "type": "decimal",
+ "min": 0,
+ "max": 5000,
+ "read_only": true,
+ "last_value": 410,
+ "unit": "ppm",
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ },
+ {
+ "name": "Door",
+ "selector": "door-opening-sensor",
+ "category": "door-opening-sensor",
+ "type": "binary",
+ "min": 0,
+ "max": 1,
+ "read_only": true,
+ "last_value": 0,
+ "unit": "percent",
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ }
+ ]
+ },
+ {
+ "id": "ab42585c-415d-4696-8f4c-ff0283dcb954",
+ "name": "Kitchen",
+ "selector": "kitchen",
+ "devices": [
+ {
+ "id": "b32daa9a-8f77-4394-b4f3-ffea215062d2",
+ "name": "Kitchen Light",
+ "selector": "sensors",
+ "features": [
+ {
+ "name": "Light",
+ "selector": "main-lamp-binary",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 100,
+ "read_only": true,
+ "last_value": 60,
+ "unit": " lux",
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ },
+ {
+ "id": "284d8f68-220c-45fd-a73a-eccb547aff24",
+ "name": "Sensor",
+ "selector": "humidity-sensor",
+ "features": [
+ {
+ "name": "Humidity",
+ "selector": "kitchen-humidity-sensor",
+ "category": "humidity-sensor",
+ "type": "decimal",
+ "min": 0,
+ "max": 100,
+ "read_only": true,
+ "last_value": 74,
+ "unit": "percent",
+ "last_value_changed": "2019-02-12 07:49:07.556 +00:00"
+ }
+ ]
+ }
+ ]
+ }
+ ],
+ "post /api/v1/light/main-lamp/on": {
+ "type": "light.turn-on",
+ "device": "main-lamp",
+ "status": "pending"
+ },
+ "get /api/v1/service/philips-hue/bridge": [
+ {
+ "name": "Philips hue",
+ "ipaddress": "192.168.2.245"
+ }
+ ],
+ "get /api/v1/message": [
+ {
+ "id": "247b1dd0-6fab-47a8-a9c8-1405deae0ae8",
+ "sender_id": null,
+ "receiver_id": "0cd30aef-9c4e-4a23-88e3-3547971296e5",
+ "text": "It's a clear day today. Temperature outside is 26°C.",
+ "is_read": true,
+ "created_at": "2019-02-12T07:45:07.556Z"
+ },
+ {
+ "id": "247b1dd0-6fab-47a8-a9c8-1405deae0ae8",
+ "sender_id": "0cd30aef-9c4e-4a23-88e3-3547971296e5",
+ "receiver_id": null,
+ "text": "What's the weather like?",
+ "is_read": true,
+ "created_at": "2019-02-12T07:44:07.556Z"
+ },
+ {
+ "id": "247b1dd0-6fab-47a8-a9c8-1405deae0ae8",
+ "sender_id": null,
+ "receiver_id": "0cd30aef-9c4e-4a23-88e3-3547971296e5",
+ "text": "It's 24°C in the kitchen.",
+ "is_read": true,
+ "created_at": "2019-02-12T07:49:07.557Z"
+ },
+ {
+ "id": "247b1dd0-6fab-47a8-a9c8-1405deae0ae8",
+ "sender_id": "0cd30aef-9c4e-4a23-88e3-3547971296e5",
+ "receiver_id": null,
+ "text": "What's the temperature in the kitchen?",
+ "is_read": true,
+ "created_at": "2019-02-12T07:49:07.556Z"
+ }
+ ],
+ "post /api/v1/message": {
+ "id": "247b1dd0-6fab-47a8-a9c8-1405deae0ae8",
+ "sender_id": "0cd30aef-9c4e-4a23-88e3-3547971296e5",
+ "receiver_id": null,
+ "text": "What time is it ?",
+ "is_read": true,
+ "created_at": "2019-02-12T07:49:07.556Z"
+ },
+ "get /api/v1/scene": [
+ {
+ "id": "5f515235-2a00-45f7-993f-cb24b463feec",
+ "selector": "wake-up",
+ "icon": "fe fe-bell",
+ "active": true,
+ "name": "Wake Up",
+ "description": "Tony's wake up scene"
+ }
+ ],
+ "get /api/v1/user": [
+ {
+ "id": "d84ced32-d937-4cf6-a32e-105ffb584226",
+ "firstname": "Tony",
+ "lastname": "Stark",
+ "selector": "tony",
+ "role": "admin"
+ },
+ {
+ "id": "2a16e6bb-34a8-46b9-90d3-275e4d059b41",
+ "firstname": "Pepper",
+ "lastname": "Pots",
+ "selector": "pepper",
+ "role": "user"
+ }
+ ],
+ "get /api/v1/user/tony": {
+ "id": "d84ced32-d937-4cf6-a32e-105ffb584226",
+ "firstname": "Tony",
+ "lastname": "Stark",
+ "selector": "tony",
+ "email": "tony.stark@gladysassistant.com",
+ "birthdate": "2011-02-04",
+ "language": "en",
+ "role": "admin"
+ },
+ "get /api/v1/user/pepper": {
+ "id": "d84ced32-d937-4cf6-a32e-105ffb584226",
+ "firstname": "Pepper",
+ "lastname": "Pots",
+ "selector": "pepper",
+ "email": "pepper.pots@gladysassistant.com",
+ "birthdate": "2011-02-04",
+ "language": "en",
+ "role": "admin"
+ },
+ "get /api/v1/scene/wake-up": {
+ "id": "5f515235-2a00-45f7-993f-cb24b463feec",
+ "selector": "wake-up",
+ "icon": "fe fe-bell",
+ "active": true,
+ "name": "Wake Up",
+ "triggers": [
+ {
+ "type": "device.new-state",
+ "device_feature": "main-lamp-binary",
+ "operator": "=",
+ "value": 1
+ }
+ ],
+ "actions": [
+ [
+ {
+ "type": "delay",
+ "value": 2,
+ "unit": "seconds"
+ }
+ ],
+ [
+ {
+ "type": "light.turn-on",
+ "devices": ["light"]
+ }
+ ]
+ ]
+ },
+ "get /api/v1/service/zwave/node": [
+ {
+ "name": "ZME_UZB1 USB Stick",
+ "features": [],
+ "params": [],
+ "rawZwaveNode": {
+ "id": 1,
+ "manufacturer": "Z-Wave.Me",
+ "manufacturerid": "0x0115",
+ "product": "ZME_UZB1 USB Stick",
+ "producttype": "0x0400",
+ "productid": "0x0001",
+ "type": "Static PC Controller"
+ }
+ }
+ ],
+ "get /api/v1/service/zwave/neighbor": [
+ {
+ "id": "1",
+ "manufacturer": "Z-Wave.Me",
+ "product": "ZME_UZB1 USB Stick",
+ "neighbors": [2, 3, 4, 5, 6, 7, 8, 10]
+ },
+ {
+ "id": "2",
+ "manufacturer": "",
+ "product": "",
+ "neighbors": []
+ },
+ {
+ "id": "3",
+ "manufacturer": "",
+ "product": "",
+ "neighbors": []
+ },
+ {
+ "id": "4",
+ "manufacturer": "",
+ "product": "",
+ "neighbors": []
+ },
+ {
+ "id": "5",
+ "manufacturer": "",
+ "product": "",
+ "neighbors": []
+ },
+ {
+ "id": "6",
+ "manufacturer": "",
+ "product": "",
+ "neighbors": []
+ },
+ {
+ "id": "7",
+ "manufacturer": "",
+ "product": "",
+ "neighbors": []
+ },
+ {
+ "id": "8",
+ "manufacturer": "",
+ "product": "",
+ "neighbors": []
+ },
+ {
+ "id": "10",
+ "manufacturer": "FIBARO System",
+ "product": "FGMS001-ZW5 Motion Sensor",
+ "neighbors": [1]
+ }
+ ],
+ "get /api/v1/service/usb/port": [
+ {
+ "comName": "/dev/tty.usbmodem145301",
+ "serialNumber": "f75ab720-bbb3-4a1c-8729-84aa02ebdca0",
+ "locationId": "14530000",
+ "vendorId": "0658",
+ "productId": "0200"
+ }
+ ],
+ "get /api/v1/area": [
+ {
+ "id": "20b4f1f0-989b-4a94-b0d4-c042137da6b5",
+ "name": "My house",
+ "radius": 1000,
+ "color": "#3498db",
+ "latitude": 41.89154462447053,
+ "longitude": 12.49828345229836
+ },
+ {
+ "id": "f7312c0d-2eac-4e89-9c78-0428e06a39f4",
+ "name": "My work",
+ "radius": 2000,
+ "color": "#f1c40f",
+ "latitude": 41.93425385676557,
+ "longitude": 12.402756238310928
+ }
+ ],
+ "get /api/v1/house": [
+ {
+ "id": "23c40ffe-e1b5-4130-b8df-c56ff92ceee5",
+ "name": "My House",
+ "selector": "my-house",
+ "latitude": 41.89154462447053,
+ "longitude": 12.49828345229836,
+ "rooms": [
+ {
+ "id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Living Room",
+ "selector": "living-room"
+ },
+ {
+ "id": "f99ab22a-e6a8-4756-b1fe-4d19dc8c8620",
+ "name": "Kitchen",
+ "selector": "kitchen"
+ },
+ {
+ "id": "01ad196a-020d-4828-a7b6-41bde8496823",
+ "name": "Garden",
+ "selector": "garden"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/zwave/device": [
+ {
+ "id": "fbedb47f-4d25-4381-8923-2633b23192a0",
+ "service_id": "a810b8db-6d04-4697-bed3-c4b72c996279",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Fibaro Motion Sensor",
+ "selector": "zwave:1234",
+ "external_id": "test-sensor-external",
+ "should_poll": false,
+ "poll_frequency": null,
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "updated_at": "2019-02-12T07:49:07.556Z",
+ "features": [
+ {
+ "name": "Temperature",
+ "selector": "test-temperature",
+ "category": "temperature-sensor",
+ "type": "decimal"
+ },
+ {
+ "name": "Motion",
+ "selector": "test-motion",
+ "category": "motion-sensor",
+ "type": "binary"
+ },
+ {
+ "name": "Battery",
+ "selector": "test-battery",
+ "category": "battery",
+ "type": "integer",
+ "last_value": "92"
+ },
+ {
+ "name": "Lux",
+ "selector": "test-light",
+ "category": "light-sensor",
+ "type": "integer"
+ }
+ ],
+ "room": {
+ "id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Living Room",
+ "selector": "living-room"
+ }
+ }
+ ],
+ "get /api/v1/service/mqtt": {},
+ "get /api/v1/service/mqtt/status": {
+ "configured": true,
+ "connected": true
+ },
+ "get /api/v1/service/mqtt/config": {
+ "useEmbeddedBroker": true,
+ "dockerBased": true,
+ "networkModeValid": true,
+ "brokerContainerAvailable": false
+ },
+ "get /api/v1/service/zigbee2mqtt": {},
+ "get /api/v1/service/zigbee2mqtt/permit_join": true,
+ "get /api/v1/service/zigbee2mqtt/device": [
+ {
+ "name": "Aqara Sensor",
+ "external_id": "zigbee2mqtt:0x00158d0005828ece",
+ "selector": "zigbee2mqtt-0x00158d0005828ece",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "model": "WSDCGQ11LM",
+ "params": [
+ {
+ "name": "model",
+ "value": "WSDCGQ11LM"
+ }
+ ],
+ "features": [
+ {
+ "category": "pressure-sensor",
+ "external_id": "zigbee2mqtt:0x00158d0005828ece:pressure-sensor:decimal:pressure",
+ "name": "Pressure Sensor",
+ "read_only": true,
+ "selector": "zigbee2mqtt:0x00158d0005828ece:pressure-sensor:decimal:pressure",
+ "type": "decimal"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/zigbee2mqtt/discovered": [
+ {
+ "name": "Aqara Sensor",
+ "external_id": "zigbee2mqtt:0x00158d0005828ece",
+ "selector": "zigbee2mqtt-0x00158d0005828ece",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "model": "WSDCGQ11LM",
+ "supported": true,
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "params": [
+ {
+ "name": "model",
+ "value": "WSDCGQ11LM"
+ }
+ ],
+ "features": [
+ {
+ "category": "pressure-sensor",
+ "external_id": "zigbee2mqtt:0x00158d0005828ece:pressure-sensor:decimal:pressure",
+ "name": "Pressure Sensor",
+ "read_only": true,
+ "selector": "zigbee2mqtt:0x00158d0005828ece:pressure-sensor:decimal:pressure",
+ "type": "decimal"
+ }
+ ]
+ },
+ {
+ "model": "WXKG01LM",
+ "name": "0x00158d00033e88d5",
+ "service_id": "f87b7af2-ca8e-44fc-b754-444354b42fee",
+ "should_poll": false,
+ "supported": true,
+ "external_id": "zigbee2mqtt:0x00158d00033e88d5",
+ "features": [
+ {
+ "category": "battery",
+ "external_id": "zigbee2mqtt:0x00158d00033e88d5:battery:integer:battery",
+ "has_feedback": false,
+ "max": 100,
+ "min": 0,
+ "name": "Battery",
+ "read_only": true,
+ "selector": "zigbee2mqtt-0x00158d00033e88d5-battery-integer-battery",
+ "type": "integer",
+ "unit": "percent"
+ },
+ {
+ "category": "button",
+ "external_id": "zigbee2mqtt:0x00158d00033e88d5:button:click:action",
+ "has_feedback": false,
+ "max": 7,
+ "min": 0,
+ "name": "Action",
+ "read_only": true,
+ "selector": "zigbee2mqtt-0x00158d00033e88d5-button-click-action",
+ "type": "click",
+ "unit": null
+ },
+ {
+ "category": "switch",
+ "external_id": "zigbee2mqtt:0x00158d00033e88d5:switch:voltage:voltage",
+ "has_feedback": false,
+ "max": 10000,
+ "min": 0,
+ "name": "Voltage",
+ "read_only": true,
+ "selector": "zigbee2mqtt-0x00158d00033e88d5-switch-voltage-voltage",
+ "type": "voltage",
+ "unit": "millivolt"
+ }
+ ]
+ },
+ {
+ "name": "Unsupported device",
+ "external_id": "zigbee2mqtt:0x00158d0005828ece",
+ "selector": "zigbee2mqtt-0x00158d0005828ece",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "supported": false,
+ "features": [
+ {
+ "category": "battery",
+ "name": "Pressure Sensor",
+ "read_only": true,
+ "type": "decimal"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/zigbee2mqtt/variable/ZIGBEE2MQTT_DRIVER_PATH": {},
+ "get /api/v1/service/zigbee2mqtt/status": {
+ "usbConfigured": true,
+ "mqttExist": true,
+ "mqttRunning": true,
+ "zigbee2mqttExist": true,
+ "zigbee2mqttRunning": true,
+ "gladysConnected": true,
+ "zigbee2mqttConnected": true,
+ "z2mEnabled": true,
+ "dockerBased": true,
+ "networkModeValid": true
+ },
+ "get /api/v1/service/tasmota": {},
+ "get /api/v1/service/tasmota/device": [
+ {
+ "name": "Switch",
+ "external_id": "tasmota:sonoff-basic",
+ "selector": "tasmota-sonoff-basic",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "model": "sonoff-basic",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ]
+ },
+ {
+ "name": "Switch",
+ "external_id": "tasmota:192.168.1.1",
+ "selector": "tasmota-192-168-1-1",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443e",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ],
+ "params": [
+ {
+ "name": "protocol",
+ "value": "http"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/device/tasmota-sonoff-basic": {
+ "name": "Switch",
+ "external_id": "tasmota:sonoff-basic",
+ "selector": "sonoff-basic",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "model": "sonoff-basic",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary",
+ "name": "Switch"
+ }
+ ]
+ },
+ "get /api/v1/device/tasmota-192-168-1-1": {
+ "name": "Switch",
+ "external_id": "tasmota:sonoff-basic",
+ "selector": "sonoff-basic",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "model": "sonoff-basic",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary",
+ "name": "Switch"
+ }
+ ]
+ },
+ "get /api/v1/service/tasmota/discover/mqtt": [
+ {
+ "name": "Sonoff Basic Kitchen",
+ "external_id": "tasmota:sonoff-basic",
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "model": "sonoff-basic",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ]
+ },
+ {
+ "name": "Sonoff Pow Kitchen",
+ "external_id": "tasmota:sonoff-pow",
+ "model": "sonoff-pow",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ]
+ },
+ {
+ "name": "Sonoff Mini Outside",
+ "external_id": "tasmota:sonoff-mini",
+ "model": "sonoff-basic",
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "updatable": true,
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/tasmota/discover/http": [
+ {
+ "name": "Sonoff Basic Kitchen",
+ "external_id": "tasmota:192.168.1.1",
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "model": "sonoff-basic",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ],
+ "params": [
+ {
+ "name": "protocol",
+ "value": "http"
+ }
+ ]
+ },
+ {
+ "name": "Sonoff Pow Kitchen",
+ "external_id": "tasmota:192.168.1.2",
+ "model": "sonoff-pow",
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ],
+ "params": [
+ {
+ "name": "protocol",
+ "value": "http"
+ }
+ ]
+ },
+ {
+ "name": "Sonoff Mini Outside",
+ "external_id": "tasmota:192.168.1.3",
+ "model": "sonoff-basic",
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "updatable": true,
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ],
+ "params": [
+ {
+ "name": "protocol",
+ "value": "http"
+ }
+ ]
+ },
+ {
+ "name": "192.168.1.3",
+ "external_id": "tasmota:192.168.1.3",
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "needAuthentication": true,
+ "features": [
+ {
+ "category": "switch",
+ "type": "binary"
+ }
+ ],
+ "params": [
+ {
+ "name": "protocol",
+ "value": "http"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/rtsp-camera/device": [
+ {
+ "id": "c2204fdc-c22f-4fc9-b7d7-c862f3c514c7",
+ "name": "Kitchen Camera",
+ "params": [
+ {
+ "name": "CAMERA_URL",
+ "value": "http://camera-url"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/rtsp-camera": {
+ "id": "aa7d6284-6b80-4e78-9e08-a4122207edcd"
+ },
+ "post /api/v1/service/rtsp-camera/camera/test": "",
+ "get /api/v1/gateway/status": {
+ "configured": false,
+ "connected": false
+ },
+ "get /api/v1/gateway/backup": [
+ {
+ "id": "99fac564-0844-44f6-866b-2b8dcf0d76eb",
+ "path": "https://url-backup",
+ "size": 1127680,
+ "created_at": "2019-06-25T07:01:24.846Z",
+ "updated_at": "2019-06-25T07:01:24.846Z",
+ "is_deleted": false
+ },
+ {
+ "id": "210460b2-c9a8-4891-9cca-464c3e19bfbb",
+ "path": "https://url-backup",
+ "size": 1013680,
+ "created_at": "2019-06-24T03:45:10.144Z",
+ "updated_at": "2019-06-24T03:45:10.144Z",
+ "is_deleted": false
+ }
+ ],
+ "get /api/v1/ping": {},
+ "get /api/v1/system/info": {
+ "hostname": "Raspberry Pi 4",
+ "type": "Linux",
+ "platform": "linux",
+ "arch": "x64",
+ "release": "18.5.0",
+ "uptime": 662555,
+ "loadavg": [1.908203125, 3.01513671875, 3.64013671875],
+ "totalmem": 17179869184,
+ "freemem": 492482560,
+ "cpus": [
+ {
+ "model": "Intel(R) Core(TM) i7-6567U CPU @ 3.30GHz",
+ "speed": 3300,
+ "times": {
+ "user": 34606730,
+ "nice": 0,
+ "sys": 24855850,
+ "idle": 100527470,
+ "irq": 0
+ }
+ },
+ {
+ "model": "Intel(R) Core(TM) i7-6567U CPU @ 3.30GHz",
+ "speed": 3300,
+ "times": {
+ "user": 22568450,
+ "nice": 0,
+ "sys": 10605290,
+ "idle": 126800520,
+ "irq": 0
+ }
+ },
+ {
+ "model": "Intel(R) Core(TM) i7-6567U CPU @ 3.30GHz",
+ "speed": 3300,
+ "times": {
+ "user": 34765800,
+ "nice": 0,
+ "sys": 20890230,
+ "idle": 104318270,
+ "irq": 0
+ }
+ },
+ {
+ "model": "Intel(R) Core(TM) i7-6567U CPU @ 3.30GHz",
+ "speed": 3300,
+ "times": {
+ "user": 18691910,
+ "nice": 0,
+ "sys": 8683980,
+ "idle": 132598350,
+ "irq": 0
+ }
+ }
+ ],
+ "network_interfaces": {},
+ "nodejs_version": "v10.15.2",
+ "gladys_version": "v4.0.0",
+ "is_docker": false,
+ "new_release_available": false
+ },
+ "get /api/v1/system/disk": {
+ "filesystem": "/dev/disk1s1",
+ "size": 499313172480,
+ "used": 464613756928,
+ "available": 28587036672,
+ "capacity": 0.953000005,
+ "mountpoint": "/"
+ },
+ "get /api/v1/system/container": [
+ {
+ "name": "/gladys",
+ "state": "running",
+ "id": "9e5f09775f897624deb1eb2ec8688c1b300d81bc3727fc71ae3290d3d8f71fa9",
+ "created_at": 1561506899
+ }
+ ],
+ "get /api/v1/service": [
+ {
+ "id": "27c96cfe-98ce-437b-a83f-5b13e0605203",
+ "pod_id": null,
+ "name": "example",
+ "selector": "example",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "LOADING",
+ "created_at": "2020-04-11T18:41:40.051Z",
+ "updated_at": "2020-10-18T10:13:22.365Z"
+ },
+ {
+ "id": "40262062-2e71-412c-8da0-70bd03f03b90",
+ "pod_id": null,
+ "name": "philips-hue",
+ "selector": "philips-hue",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-04-11T18:41:40.052Z",
+ "updated_at": "2020-10-30T07:44:07.731Z"
+ },
+ {
+ "id": "4cd73c14-a929-4af0-a5e2-baed35802224",
+ "pod_id": null,
+ "name": "rtsp-camera",
+ "selector": "rtsp-camera",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-04-11T18:41:40.053Z",
+ "updated_at": "2020-10-30T07:44:07.694Z"
+ },
+ {
+ "id": "0c27de72-ced7-4f7f-8950-473b9e904e71",
+ "pod_id": null,
+ "name": "telegram",
+ "selector": "telegram",
+ "version": "0.1.0",
+ "has_message_feature": true,
+ "status": "RUNNING",
+ "created_at": "2020-04-11T18:41:40.053Z",
+ "updated_at": "2020-10-30T07:44:07.518Z"
+ },
+ {
+ "id": "09a3e250-940a-4f52-8595-e6268ffd7198",
+ "pod_id": null,
+ "name": "usb",
+ "selector": "usb",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-04-11T18:41:40.053Z",
+ "updated_at": "2020-10-30T07:44:07.660Z"
+ },
+ {
+ "id": "366fd9d7-bfbf-4c13-bd8c-4cc777799142",
+ "pod_id": null,
+ "name": "xiaomi",
+ "selector": "xiaomi",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-04-11T18:41:40.055Z",
+ "updated_at": "2020-10-30T07:44:07.474Z"
+ },
+ {
+ "id": "3772bbf5-b1d7-441f-9bd4-ef94920e31cd",
+ "pod_id": null,
+ "name": "zwave",
+ "selector": "zwave",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-04-11T18:41:40.056Z",
+ "updated_at": "2020-10-30T07:44:07.594Z"
+ },
+ {
+ "id": "7355bc7f-4109-40ba-819f-fb03f91969b0",
+ "pod_id": null,
+ "name": "tasmota",
+ "selector": "tasmota",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-04-11T18:41:40.056Z",
+ "updated_at": "2020-10-30T07:44:07.627Z"
+ },
+ {
+ "id": "2e0bc58b-11e2-4176-8ad3-9ebc8cdd2318",
+ "pod_id": null,
+ "name": "mqtt",
+ "selector": "mqtt",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "ERROR",
+ "created_at": "2020-04-11T18:41:40.057Z",
+ "updated_at": "2020-10-30T07:44:07.785Z"
+ },
+ {
+ "id": "d97ba3fa-872f-4ecc-879f-46c55a2930c6",
+ "pod_id": null,
+ "name": "google-actions",
+ "selector": "google-actions",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "UNKNOWN",
+ "created_at": "2020-04-11T18:41:40.111Z",
+ "updated_at": "2020-04-11T18:41:40.111Z"
+ },
+ {
+ "id": "6d3c7a63-e4b8-4650-bcd3-50cf42b2996f",
+ "pod_id": null,
+ "name": "caldav",
+ "selector": "caldav",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-04-16T19:38:21.885Z",
+ "updated_at": "2020-10-30T07:44:07.558Z"
+ },
+ {
+ "id": "39a278e9-66da-47cb-bdaa-264ba6418091",
+ "pod_id": null,
+ "name": "openweather",
+ "selector": "openweather",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-08-19T13:04:57.309Z",
+ "updated_at": "2020-10-30T07:44:07.814Z"
+ },
+ {
+ "id": "9682e167-e07f-4823-bd31-a60f957842e0",
+ "pod_id": null,
+ "name": "broadlink",
+ "selector": "broadlink",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "UNKNOWN",
+ "created_at": "2020-08-30T15:55:19.467Z",
+ "updated_at": "2020-08-30T15:55:19.467Z"
+ },
+ {
+ "id": "d6ea610f-1e33-4c08-89a3-1c8be2cc45f9",
+ "pod_id": null,
+ "name": "bluetooth",
+ "selector": "bluetooth",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "LOADING",
+ "created_at": "2020-09-02T12:35:32.763Z",
+ "updated_at": "2020-10-18T09:28:14.935Z"
+ },
+ {
+ "id": "c9fe2705-35dc-417b-b6fc-c4bbb9c69886",
+ "pod_id": null,
+ "name": "tp-link",
+ "selector": "tp-link",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-11-11T18:41:40.052Z",
+ "updated_at": "2020-11-28T07:44:07.731Z"
+ }
+ ],
+ "get /api/v1/session": [
+ {
+ "id": "4b249694-661b-4c48-afb5-924bbedcee63",
+ "token_type": "refresh_token",
+ "scope": ["dashboard:write", "dashboard:read"],
+ "valid_until": "2019-07-26T01:00:50.137Z",
+ "last_seen": null,
+ "revoked": false,
+ "useragent": "Mozilla/5.0 (Linux; Android 6.0.1; SHIELD Tablet K1 Build/MRA58K; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/55.0.2883.91 Safari/537.36",
+ "created_at": "2019-06-26T01:00:50.138Z",
+ "updated_at": "2019-06-26T01:00:50.138Z"
+ },
+ {
+ "id": "2367a8cf-47a8-4db7-83b0-f89c2c6c34ac",
+ "token_type": "refresh_token",
+ "scope": ["dashboard:write", "dashboard:read"],
+ "valid_until": "2019-07-26T00:29:00.783Z",
+ "last_seen": null,
+ "revoked": false,
+ "useragent": "Mozilla/5.0 (iPhone; CPU iPhone OS 12_0 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0 Mobile/15E148 Safari/604.1",
+ "created_at": "2019-06-26T00:29:00.783Z",
+ "updated_at": "2019-06-26T00:29:00.783Z"
+ },
+ {
+ "id": "2367a8cf-47a8-4db7-83b0-f89c2c6c34ac",
+ "token_type": "refresh_token",
+ "scope": ["dashboard:write", "dashboard:read"],
+ "valid_until": "2019-07-26T00:29:00.783Z",
+ "last_seen": null,
+ "revoked": false,
+ "useragent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.135 Safari/537.36 Edge/12.246",
+ "created_at": "2019-06-26T00:29:00.783Z",
+ "updated_at": "2019-06-26T00:29:00.783Z"
+ },
+ {
+ "id": "2367a8cf-47a8-4db7-83b0-f89c2c6c34ac",
+ "token_type": "refresh_token",
+ "scope": ["dashboard:write", "dashboard:read"],
+ "valid_until": "2019-07-26T00:29:00.783Z",
+ "last_seen": null,
+ "revoked": false,
+ "created_at": "2019-06-26T00:29:00.783Z",
+ "updated_at": "2019-06-26T00:29:00.783Z"
+ }
+ ],
+ "get /api/v1/setup": {
+ "account_configured": true
+ },
+ "get /api/v1/service/xiaomi/sensor": [
+ {
+ "name": "Xiaomi Temperature",
+ "external_id": "xiaomi:1234",
+ "selector": "xiaomi:1234",
+ "features": [
+ {
+ "name": "Temperature",
+ "selector": "xiaomi:12344:temperature",
+ "external_id": "xiaomi:12344:temperature",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "unit": "celsius",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": -20,
+ "max": 60
+ },
+ {
+ "name": "Humidity",
+ "selector": "xiaomi:12344:humidity",
+ "external_id": "xiaomi:12344:humidity",
+ "category": "humidity-sensor",
+ "type": "decimal",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ },
+ {
+ "name": "Battery",
+ "selector": "xiaomi:12344:battery",
+ "external_id": "xiaomi:12344:battery",
+ "category": "battery",
+ "type": "integer",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/xiaomi/device": [
+ {
+ "id": "e5317b24-28e1-4839-9879-0bb7a3102e98",
+ "name": "Xiaomi Temperature",
+ "external_id": "xiaomi:1234",
+ "selector": "xiaomi:1234",
+ "room_id": "f99ab22a-e6a8-4756-b1fe-4d19dc8c8620",
+ "service_id": "70cb1e17-3b17-4886-83ab-45b00a9e03b1",
+ "features": [
+ {
+ "name": "Temperature",
+ "selector": "xiaomi:12344:temperature",
+ "external_id": "xiaomi:12344:temperature",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "unit": "celsius",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": -20,
+ "max": 60
+ },
+ {
+ "name": "Humidity",
+ "selector": "xiaomi:12344:humidity",
+ "external_id": "xiaomi:12344:humidity",
+ "category": "humidity-sensor",
+ "type": "decimal",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ },
+ {
+ "name": "Battery",
+ "selector": "xiaomi:12344:battery",
+ "external_id": "xiaomi:12344:battery",
+ "category": "battery",
+ "type": "integer",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ }
+ ]
+ }
+ ],
+ "get /api/v1/device": [
+ {
+ "id": "06e735a3-ac62-4a05-85b6-855f2c556d7b",
+ "name": "Living room lamp",
+ "selector": "light",
+ "features": [
+ {
+ "name": "Living room lamp",
+ "type": "binary",
+ "selector": "light.binary",
+ "category": "light"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/xiaomi": {
+ "id": "70cb1e17-3b17-4886-83ab-45b00a9e03b1",
+ "name": "Xiaomi",
+ "selector": "xiaomi"
+ },
+ "get /api/v1/device/zwave:1234": {
+ "id": "fbedb47f-4d25-4381-8923-2633b23192a0",
+ "service_id": "a810b8db-6d04-4697-bed3-c4b72c996279",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Fibaro Motion Sensor",
+ "selector": "zwave:1234",
+ "external_id": "test-sensor-external",
+ "should_poll": false,
+ "poll_frequency": null,
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "updated_at": "2019-02-12T07:49:07.556Z",
+ "features": [
+ {
+ "name": "Temperature",
+ "external_id": "zwave:1234:temperature",
+ "selector": "test-temperature",
+ "category": "temperature-sensor",
+ "unit": "celsius",
+ "type": "decimal"
+ },
+ {
+ "name": "Motion",
+ "selector": "test-motion",
+ "external_id": "zwave:1234:temperature",
+ "category": "motion-sensor",
+ "type": "binary"
+ },
+ {
+ "name": "Battery",
+ "selector": "test-battery",
+ "external_id": "zwave:1234:temperature",
+ "category": "battery",
+ "type": "integer",
+ "last_value": "92"
+ },
+ {
+ "name": "Lux",
+ "selector": "test-light",
+ "external_id": "zwave:1234:temperature",
+ "category": "light-sensor",
+ "type": "integer"
+ }
+ ],
+ "room": {
+ "id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Living Room",
+ "selector": "living-room"
+ }
+ },
+ "get /api/v1/service/zwave": {
+ "id": "a810b8db-6d04-4697-bed3-c4b72c996279",
+ "name": "Zwave",
+ "selector": "zwave"
+ },
+ "get /api/v1/device/xiaomi:1234": {
+ "id": "e5317b24-28e1-4839-9879-0bb7a3102e98",
+ "name": "Xiaomi Temperature",
+ "external_id": "xiaomi:1234",
+ "selector": "xiaomi:1234",
+ "room_id": "f99ab22a-e6a8-4756-b1fe-4d19dc8c8620",
+ "service_id": "70cb1e17-3b17-4886-83ab-45b00a9e03b1",
+ "features": [
+ {
+ "name": "Temperature",
+ "selector": "xiaomi:12344:temperature",
+ "external_id": "xiaomi:12344:temperature",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "unit": "celsius",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": -20,
+ "max": 60
+ },
+ {
+ "name": "Humidity",
+ "selector": "xiaomi:12344:humidity",
+ "external_id": "xiaomi:12344:humidity",
+ "category": "humidity-sensor",
+ "type": "decimal",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ },
+ {
+ "name": "Battery",
+ "selector": "xiaomi:12344:battery",
+ "external_id": "xiaomi:12344:battery",
+ "category": "battery",
+ "type": "integer",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ }
+ ]
+ },
+ "get /api/v1/service/philips-hue": {
+ "id": "1147bdef-0c95-40f1-a7ef-922ebcad7d0e",
+ "name": "Philips Hue",
+ "selector": "philips-hue"
+ },
+ "get /api/v1/service/philips-hue/light": [
+ {
+ "id": "1",
+ "name": "New Lamp",
+ "model": "LCT007",
+ "external_id": "philips-hue:4"
+ },
+ {
+ "id": "2",
+ "name": "Living room lamp",
+ "model": "LCT007",
+ "external_id": "philips-hue:5"
+ }
+ ],
+ "get /api/v1/service/philips-hue/device": [
+ {
+ "id": "1",
+ "name": "Lounge Living Color",
+ "model": "LCT007",
+ "external_id": "philips-hue:1",
+ "features": [
+ {
+ "name": "On/Off",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 1
+ },
+ {
+ "name": "Color",
+ "category": "light",
+ "type": "color",
+ "min": 0,
+ "max": 1
+ }
+ ]
+ },
+ {
+ "id": "2",
+ "name": "Right Bedside",
+ "type": "Extended color light",
+ "model": "LCT001",
+ "external_id": "philips-hue:2",
+ "features": [
+ {
+ "name": "On/Off",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 1
+ },
+ {
+ "name": "Color",
+ "category": "light",
+ "type": "color",
+ "min": 0,
+ "max": 1
+ }
+ ]
+ },
+ {
+ "id": "3",
+ "name": "Left Bedside",
+ "type": "Extended color light",
+ "model": "LCT001",
+ "external_id": "philips-hue:3",
+ "features": [
+ {
+ "name": "On/Off",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 1
+ },
+ {
+ "name": "Color",
+ "category": "light",
+ "type": "color",
+ "min": 0,
+ "max": 1
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/bluetooth": {
+ "id": "a810b8db-6d04-4697-bed3-c4b72c996279",
+ "name": "bluetooth",
+ "enabled": true
+ },
+ "get /api/v1/service/bluetooth/config": {
+ "presenceScanner": {
+ "status": "enabled",
+ "frequency": 60000
+ }
+ },
+ "get /api/v1/service/bluetooth/device": [
+ {
+ "id": "fbedb47f-4d25-4381-8923-2633b23192a0",
+ "service_id": "a810b8db-6d04-4697-bed3-c4b72c996279",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Nut Smart Tracker",
+ "selector": "bluetooth-sensor",
+ "external_id": "test-sensor-external",
+ "should_poll": false,
+ "poll_frequency": null,
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "updated_at": "2019-02-12T07:49:07.556Z",
+ "features": [
+ {
+ "name": "Battery",
+ "selector": "test-battery",
+ "category": "battery",
+ "type": "integer",
+ "last_value": "12"
+ }
+ ],
+ "room": {
+ "id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Living Room",
+ "selector": "living-room"
+ }
+ }
+ ],
+ "get /api/v1/device/bluetooth-sensor": {
+ "id": "fbedb47f-4d25-4381-8923-2633b23192a0",
+ "service_id": "a810b8db-6d04-4697-bed3-c4b72c996279",
+ "room_id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Nut Smart Tracker",
+ "selector": "bluetooth-sensor",
+ "external_id": "bluetooth:external",
+ "should_poll": false,
+ "poll_frequency": null,
+ "created_at": "2019-02-12T07:49:07.556Z",
+ "updated_at": "2019-02-12T07:49:07.556Z",
+ "features": [
+ {
+ "name": "Battery",
+ "selector": "test-battery",
+ "category": "battery",
+ "type": "integer",
+ "last_value": "12"
+ }
+ ],
+ "room": {
+ "id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Living Room",
+ "selector": "living-room"
+ }
+ },
+ "get /api/v1/service/bluetooth/status": {
+ "ready": true
+ },
+ "get /api/v1/service/bluetooth/peripheral": [
+ {
+ "name": "BLE Device 1",
+ "external_id": "bluetooth:0011223341",
+ "service_id": "a810b8db-6d04-4697-bed3-c4b72c996279",
+ "selector": "bluetooth-0011223341",
+ "params": [
+ {
+ "name": "loaded",
+ "value": false
+ }
+ ]
+ },
+ {
+ "name": "SML c9",
+ "model": "smlc9",
+ "external_id": "bluetooth:0011223342",
+ "selector": "bluetooth-0011223342",
+ "params": [
+ {
+ "name": "loaded",
+ "value": true
+ },
+ {
+ "name": "manufacturer",
+ "value": "AwoX"
+ }
+ ]
+ },
+ {
+ "name": "Peanut temperature",
+ "external_id": "bluetooth:0011223343",
+ "service_id": "a810b8db-6d04-4697-bed3-c4b72c996278",
+ "service": {
+ "name": "peanut"
+ },
+ "selector": "bluetooth-0011223343",
+ "params": [
+ {
+ "name": "loaded",
+ "value": true
+ },
+ {
+ "name": "manufacturer",
+ "value": "Peanut"
+ }
+ ],
+ "features": [
+ {
+ "name": "Battery",
+ "category": "battery",
+ "type": "integer",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ },
+ {
+ "name": "Temperature",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": -100,
+ "max": 250
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/bluetooth/peripheral/bluetooth-0011223341": {
+ "name": "BLE Device 1",
+ "external_id": "bluetooth:0011223341",
+ "selector": "bluetooth-0011223341",
+ "params": [
+ {
+ "name": "loaded",
+ "value": false
+ }
+ ]
+ },
+ "get /api/v1/service/bluetooth/peripheral/bluetooth-0011223342": {
+ "name": "SML c9",
+ "model": "smlc9",
+ "external_id": "bluetooth:0011223342",
+ "selector": "bluetooth-0011223342",
+ "params": [
+ {
+ "name": "loaded",
+ "value": true
+ },
+ {
+ "name": "manufacturer",
+ "value": "AwoX"
+ }
+ ]
+ },
+ "get /api/v1/service/bluetooth/peripheral/bluetooth-0011223343": {
+ "name": "Peanut temperature",
+ "external_id": "bluetooth:0011223343",
+ "selector": "bluetooth-0011223343",
+ "params": [
+ {
+ "name": "loaded",
+ "value": true
+ },
+ {
+ "name": "manufacturer",
+ "value": "Peanut"
+ }
+ ],
+ "features": [
+ {
+ "name": "Battery",
+ "category": "battery",
+ "type": "integer",
+ "unit": "percent",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": 0,
+ "max": 100
+ },
+ {
+ "name": "Temperature",
+ "category": "temperature-sensor",
+ "type": "decimal",
+ "read_only": true,
+ "keep_history": true,
+ "has_feedback": true,
+ "min": -100,
+ "max": 250
+ }
+ ]
+ },
+ "get /api/v1/service/ewelink": {
+ "id": "45c792a5-051b-4e6f-b746-2dd4c77d9d31",
+ "name": "ewelink",
+ "selector": "ewelink"
+ },
+ "get api/v1/service/ewelink/device": [
+ {
+ "id": "28e8ad03-70a8-431f-93cb-df916019c509",
+ "room_id": "568981d0-1a4d-40ea-af97-dd4037d2b344",
+ "name": "Switch 1",
+ "selector": "ewelink-1000768322-0",
+ "model": "MINI",
+ "external_id": "ewelink:1000768322:0",
+ "should_poll": true,
+ "poll_frequency": 60000,
+ "features": [
+ {
+ "id": "6f8172ed-37e5-4785-94ad-ec33706a31f3",
+ "device_id": "28e8ad03-70a8-431f-93cb-df916019c509",
+ "name": "Switch 1 On/Off",
+ "selector": "ewelink-1000768322-0-binary",
+ "external_id": "ewelink:1000768322:0:binary",
+ "category": "switch",
+ "type": "binary",
+ "read_only": false,
+ "has_feedback": false,
+ "min": 0,
+ "max": 1
+ }
+ ],
+ "params": [
+ {
+ "id": "5e1ef948-305b-44c5-bb78-78952b1f5cb2",
+ "device_id": "28e8ad03-70a8-431f-93cb-df916019c509",
+ "name": "IP_ADDRESS",
+ "value": "0.0.0.1"
+ },
+ {
+ "id": "f3a6f3fa-a7b0-4968-b9fd-2e492ced2274",
+ "device_id": "28e8ad03-70a8-431f-93cb-df916019c509",
+ "name": "FIRMWARE",
+ "value": "3.3.0"
+ }
+ ],
+ "room": {
+ "id": "cecc52c7-3e67-4b75-9b13-9a8867b0443d",
+ "name": "Living Room",
+ "selector": "living-room"
+ },
+ "service": {
+ "id": "45c792a5-051b-4e6f-b746-2dd4c77d9d31",
+ "name": "ewelink",
+ "selector": "ewelink"
+ }
+ }
+ ],
+ "get api/v1/service/ewelink/discover": [
+ {
+ "service_id": "45c792a5-051b-4e6f-b746-2dd4c77d9d31",
+ "name": "Switch 2",
+ "model": "Basic",
+ "external_id": "ewelink:10004636bf:0",
+ "selector": "ewelink:10004636bf:0",
+ "should_poll": true,
+ "poll_frequency": 60000,
+ "features": [
+ {
+ "name": "Switch 2 On/Off",
+ "external_id": "ewelink:10004636bf:0:binary",
+ "selector": "ewelink:10004636bf:0:binary",
+ "category": "switch",
+ "type": "binary",
+ "read_only": false,
+ "has_feedback": false,
+ "min": 0,
+ "max": 1
+ }
+ ],
+ "params": [
+ {
+ "name": "IP_ADDRESS",
+ "value": "0.0.0.2"
+ },
+ {
+ "name": "FIRMWARE",
+ "value": "3.2.1"
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/tp-link": {
+ "id": "c9fe2705-35dc-417b-b6fc-c4bbb9c69886",
+ "pod_id": null,
+ "name": "tp-link",
+ "selector": "tp-link",
+ "version": "0.1.0",
+ "has_message_feature": false,
+ "status": "RUNNING",
+ "created_at": "2020-11-11T18:41:40.052Z",
+ "updated_at": "2020-11-28T07:44:07.731Z"
+ },
+ "get /api/v1/service/tp-link/device": [
+ {
+ "id": "1",
+ "name": "Plug Coffee Machine",
+ "model": "HS100",
+ "external_id": "tp-link-1",
+ "features": [
+ {
+ "name": "On/Off",
+ "category": "switch",
+ "type": "binary",
+ "min": 0,
+ "max": 1
+ }
+ ]
+ },
+ {
+ "id": "2",
+ "name": "Light Swimming Pool",
+ "model": "LB100",
+ "external_id": "tp-link-2",
+ "features": [
+ {
+ "name": "On/Off",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 1
+ }
+ ]
+ }
+ ],
+ "get /api/v1/service/tp-link/scan": [
+ {
+ "id": "3",
+ "name": "Plug TV Dock",
+ "model": "HS100",
+ "external_id": "tp-link-3",
+ "features": [
+ {
+ "name": "On/Off",
+ "category": "switch",
+ "type": "binary",
+ "min": 0,
+ "max": 1
+ }
+ ]
+ },
+ {
+ "id": "4",
+ "name": "Light Bedroom",
+ "model": "LB100",
+ "external_id": "tp-link-4",
+ "features": [
+ {
+ "name": "On/Off",
+ "category": "light",
+ "type": "binary",
+ "min": 0,
+ "max": 1
+ }
+ ]
+ }
+ ]
+}
diff --git a/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js b/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
index 79859ca114..37ba70c890 100644
--- a/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
+++ b/front/src/routes/integration/all/zigbee2mqtt/discover-page/actions.js
@@ -13,7 +13,7 @@ function createActions(store) {
});
try {
- const zigbee2mqttDevices = await state.httpClient.get('/api/v1/service/zigbee2mqtt/device');
+ const zigbee2mqttDevices = await state.httpClient.get('/api/v1/service/zigbee2mqtt/discovered');
store.setState({ zigbee2mqttDevices, discoverZigbee2mqtt: false });
} catch (e) {
store.setState({
diff --git a/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js b/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
index 31a1e85915..c14929a254 100644
--- a/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
+++ b/server/services/zigbee2mqtt/api/zigbee2mqtt.controller.js
@@ -3,7 +3,7 @@ const logger = require('../../../utils/logger');
module.exports = function Zigbee2mqttController(gladys, zigbee2mqttManager) {
/**
- * @api {get} /api/v1/service/zigbee2mqtt/device Get discovered Zigbee2mqtt devices
+ * @api {get} /api/v1/service/zigbee2mqtt/discovered Get discovered Zigbee2mqtt devices
* @apiName getDiscoveredDevices
* @apiGroup Zigbee2mqtt
*/
@@ -101,7 +101,7 @@ module.exports = function Zigbee2mqttController(gladys, zigbee2mqttManager) {
}
return {
- 'get /api/v1/service/zigbee2mqtt/device': {
+ 'get /api/v1/service/zigbee2mqtt/discovered': {
authenticated: true,
controller: asyncMiddleware(getDiscoveredDevices),
},
diff --git a/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js b/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
index 8397994f81..cb2de44cfa 100644
--- a/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
+++ b/server/test/services/zigbee2mqtt/api/zigbee2mqtt.controller.test.js
@@ -29,13 +29,13 @@ describe('zigbee2mqtt API', () => {
sinon.reset();
});
- it('get /api/v1/service/zigbee2mqtt/device', async () => {
+ it('get /api/v1/service/zigbee2mqtt/discovered', async () => {
const req = {};
const res = {
json: fake.returns(null),
};
- await controller['get /api/v1/service/zigbee2mqtt/device'].controller(req, res);
+ await controller['get /api/v1/service/zigbee2mqtt/discovered'].controller(req, res);
assert.calledOnce(zigbee2mqttManager.getDiscoveredDevices);
assert.calledWith(res.json, ['device']);
From 27ca5d2878148da75ab4eafa2b1154b63034baa2 Mon Sep 17 00:00:00 2001
From: atrovato <1839717+atrovato@users.noreply.github.com>
Date: Mon, 1 Nov 2021 08:33:59 +0100
Subject: [PATCH 9/9] remove formaldehyd
---
server/services/zigbee2mqtt/exposes/numericType.js | 6 ------
1 file changed, 6 deletions(-)
diff --git a/server/services/zigbee2mqtt/exposes/numericType.js b/server/services/zigbee2mqtt/exposes/numericType.js
index ce2cd9b9bd..fef9b07957 100644
--- a/server/services/zigbee2mqtt/exposes/numericType.js
+++ b/server/services/zigbee2mqtt/exposes/numericType.js
@@ -100,12 +100,6 @@ module.exports = {
unit: DEVICE_FEATURE_UNITS.KILOWATT_HOUR,
},
},
- formaldehyd: {
- feature: {
- category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,
- type: DEVICE_FEATURE_TYPES.SENSOR.DECIMAL,
- },
- },
gas: {
feature: {
category: DEVICE_FEATURE_CATEGORIES.SMOKE_SENSOR,