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,