@switchbot/homebridge-switchbot 5.0.0-beta.7 → 5.0.0-beta.71
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/ISSUE_TEMPLATE/e2e-verification.md +36 -0
- package/.github/workflows/ci.yml +61 -0
- package/.github/workflows/manual-e2e.yml +103 -0
- package/CHANGELOG.md +35 -0
- package/E2E-VERIFICATION.md +121 -0
- package/MIGRATION.md +44 -0
- package/README.md +56 -3
- package/config.schema.json +99 -14823
- package/dist/deviceFactory.d.ts +13 -0
- package/dist/deviceFactory.d.ts.map +1 -0
- package/dist/deviceFactory.js +81 -0
- package/dist/deviceFactory.js.map +1 -0
- package/dist/devices/deviceBase.d.ts +50 -0
- package/dist/devices/deviceBase.d.ts.map +1 -0
- package/dist/devices/deviceBase.js +119 -0
- package/dist/devices/deviceBase.js.map +1 -0
- package/dist/devices/genericDevice.d.ts +283 -0
- package/dist/devices/genericDevice.d.ts.map +1 -0
- package/dist/devices/genericDevice.js +1035 -0
- package/dist/devices/genericDevice.js.map +1 -0
- package/dist/homebridge-ui/public/index.html +77 -245
- package/dist/homebridge-ui/server.d.ts +3 -1
- package/dist/homebridge-ui/server.d.ts.map +1 -1
- package/dist/homebridge-ui/server.js +42 -36
- package/dist/homebridge-ui/server.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -12
- package/dist/index.js.map +1 -1
- package/dist/platform.d.ts +27 -0
- package/dist/platform.d.ts.map +1 -0
- package/dist/platform.js +404 -0
- package/dist/platform.js.map +1 -0
- package/dist/settings.d.ts +10 -249
- package/dist/settings.d.ts.map +1 -1
- package/dist/settings.js +5 -30
- package/dist/settings.js.map +1 -1
- package/dist/switchbotClient.d.ts +32 -0
- package/dist/switchbotClient.d.ts.map +1 -0
- package/dist/switchbotClient.js +259 -0
- package/dist/switchbotClient.js.map +1 -0
- package/dist/utils.d.ts +39 -50
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +39 -688
- package/dist/utils.js.map +1 -1
- package/docs/assets/highlight.css +14 -0
- package/docs/assets/icons.js +1 -1
- package/docs/assets/icons.svg +1 -1
- package/docs/assets/main.js +2 -2
- package/docs/assets/style.css +3 -3
- package/docs/index.html +77 -13
- package/docs/variables/default.html +1 -1
- package/package.json +22 -21
- package/scripts/e2e/README.md +25 -0
- package/scripts/e2e/curtain-e2e.sh +70 -0
- package/scripts/e2e/fan-e2e.sh +75 -0
- package/scripts/e2e/light-advanced-e2e.sh +97 -0
- package/scripts/e2e/light-e2e.sh +75 -0
- package/scripts/e2e/list-accessories.sh +19 -0
- package/scripts/e2e/lock-e2e.sh +65 -0
- package/scripts/generate-matter-maps.js +60 -0
- package/scripts/run-e2e-local.sh +14 -0
- package/src/deviceFactory.ts +122 -0
- package/src/devices/deviceBase.ts +141 -0
- package/src/devices/genericDevice.ts +965 -0
- package/src/homebridge-ui/public/index.html +77 -245
- package/src/homebridge-ui/server.ts +49 -41
- package/src/index.ts +5 -13
- package/src/platform.ts +395 -0
- package/src/settings.ts +12 -277
- package/src/switchbotClient.ts +266 -0
- package/src/utils.ts +45 -713
- package/test/accessory-restore.spec.ts +73 -0
- package/test/device-mapping.spec.ts +37 -0
- package/test/deviceFactory.spec.ts +18 -0
- package/test/e2e/run-e2e.spec.ts +50 -0
- package/test/fan-swing.spec.ts +29 -0
- package/test/helpers/matter-harness.ts +53 -0
- package/test/lock-users.spec.ts +44 -0
- package/test/matter-childbridge.spec.ts +55 -0
- package/test/matter-descriptors.spec.ts +97 -0
- package/test/matter-device-state.spec.ts +101 -0
- package/test/matter-integration.spec.ts +70 -0
- package/test/platform.integration.spec.ts +55 -0
- package/test/switchbot-client-debounce.spec.ts +131 -0
- package/test/switchbot-client-openapi.spec.ts +56 -0
- package/test/switchbotClient.spec.ts +10 -0
- package/test/utils.spec.ts +20 -0
- package/vitest.config.ts +7 -0
- package/coverage/base.css +0 -224
- package/coverage/block-navigation.js +0 -87
- package/coverage/clover.xml +0 -15847
- package/coverage/coverage-final.json +0 -42
- package/coverage/docs/assets/dmt/dmt-component-data.js.html +0 -85
- package/coverage/docs/assets/dmt/dmt-components.js.html +0 -286
- package/coverage/docs/assets/dmt/index.html +0 -131
- package/coverage/docs/assets/hierarchy.js.html +0 -85
- package/coverage/docs/assets/icons.js.html +0 -136
- package/coverage/docs/assets/index.html +0 -146
- package/coverage/docs/assets/main.js.html +0 -265
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +0 -191
- package/coverage/prettify.css +0 -1
- package/coverage/prettify.js +0 -2
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +0 -196
- package/coverage/src/device/blindtilt.ts.html +0 -3238
- package/coverage/src/device/bot.ts.html +0 -2803
- package/coverage/src/device/ceilinglight.ts.html +0 -2338
- package/coverage/src/device/colorbulb.ts.html +0 -2824
- package/coverage/src/device/contact.ts.html +0 -1465
- package/coverage/src/device/curtain.ts.html +0 -2869
- package/coverage/src/device/device.ts.html +0 -2500
- package/coverage/src/device/fan.ts.html +0 -2242
- package/coverage/src/device/hub.ts.html +0 -1408
- package/coverage/src/device/humidifier.ts.html +0 -2116
- package/coverage/src/device/index.html +0 -416
- package/coverage/src/device/iosensor.ts.html +0 -1375
- package/coverage/src/device/lightstrip.ts.html +0 -2617
- package/coverage/src/device/lock.ts.html +0 -1963
- package/coverage/src/device/meter.ts.html +0 -1372
- package/coverage/src/device/meterplus.ts.html +0 -1384
- package/coverage/src/device/meterpro.ts.html +0 -1618
- package/coverage/src/device/motion.ts.html +0 -1264
- package/coverage/src/device/plug.ts.html +0 -1372
- package/coverage/src/device/relayswitch.ts.html +0 -2284
- package/coverage/src/device/robotvacuumcleaner.ts.html +0 -1810
- package/coverage/src/device/waterdetector.ts.html +0 -1294
- package/coverage/src/homebridge-ui/index.html +0 -116
- package/coverage/src/homebridge-ui/server.ts.html +0 -229
- package/coverage/src/index.html +0 -161
- package/coverage/src/index.ts.html +0 -124
- package/coverage/src/irdevice/airconditioner.ts.html +0 -1687
- package/coverage/src/irdevice/airpurifier.ts.html +0 -844
- package/coverage/src/irdevice/camera.ts.html +0 -475
- package/coverage/src/irdevice/fan.ts.html +0 -766
- package/coverage/src/irdevice/index.html +0 -251
- package/coverage/src/irdevice/irdevice.ts.html +0 -1117
- package/coverage/src/irdevice/light.ts.html +0 -826
- package/coverage/src/irdevice/other.ts.html +0 -2458
- package/coverage/src/irdevice/tv.ts.html +0 -1222
- package/coverage/src/irdevice/vacuumcleaner.ts.html +0 -466
- package/coverage/src/irdevice/waterheater.ts.html +0 -469
- package/coverage/src/platform.ts.html +0 -8776
- package/coverage/src/settings.ts.html +0 -934
- package/coverage/src/utils.ts.html +0 -2092
- package/dist/devices-hap/airpurifier.d.ts +0 -54
- package/dist/devices-hap/airpurifier.d.ts.map +0 -1
- package/dist/devices-hap/airpurifier.js +0 -527
- package/dist/devices-hap/airpurifier.js.map +0 -1
- package/dist/devices-hap/blindtilt.d.ts +0 -90
- package/dist/devices-hap/blindtilt.d.ts.map +0 -1
- package/dist/devices-hap/blindtilt.js +0 -974
- package/dist/devices-hap/blindtilt.js.map +0 -1
- package/dist/devices-hap/bot.d.ts +0 -102
- package/dist/devices-hap/bot.d.ts.map +0 -1
- package/dist/devices-hap/bot.js +0 -811
- package/dist/devices-hap/bot.js.map +0 -1
- package/dist/devices-hap/ceilinglight.d.ts +0 -85
- package/dist/devices-hap/ceilinglight.d.ts.map +0 -1
- package/dist/devices-hap/ceilinglight.js +0 -701
- package/dist/devices-hap/ceilinglight.js.map +0 -1
- package/dist/devices-hap/colorbulb.d.ts +0 -88
- package/dist/devices-hap/colorbulb.d.ts.map +0 -1
- package/dist/devices-hap/colorbulb.js +0 -881
- package/dist/devices-hap/colorbulb.js.map +0 -1
- package/dist/devices-hap/contact.d.ts +0 -44
- package/dist/devices-hap/contact.d.ts.map +0 -1
- package/dist/devices-hap/contact.js +0 -409
- package/dist/devices-hap/contact.js.map +0 -1
- package/dist/devices-hap/curtain.d.ts +0 -73
- package/dist/devices-hap/curtain.d.ts.map +0 -1
- package/dist/devices-hap/curtain.js +0 -869
- package/dist/devices-hap/curtain.js.map +0 -1
- package/dist/devices-hap/device.d.ts +0 -98
- package/dist/devices-hap/device.d.ts.map +0 -1
- package/dist/devices-hap/device.js +0 -749
- package/dist/devices-hap/device.js.map +0 -1
- package/dist/devices-hap/fan.d.ts +0 -69
- package/dist/devices-hap/fan.d.ts.map +0 -1
- package/dist/devices-hap/fan.js +0 -649
- package/dist/devices-hap/fan.js.map +0 -1
- package/dist/devices-hap/hub.d.ts +0 -37
- package/dist/devices-hap/hub.d.ts.map +0 -1
- package/dist/devices-hap/hub.js +0 -392
- package/dist/devices-hap/hub.js.map +0 -1
- package/dist/devices-hap/humidifier.d.ts +0 -68
- package/dist/devices-hap/humidifier.d.ts.map +0 -1
- package/dist/devices-hap/humidifier.js +0 -628
- package/dist/devices-hap/humidifier.js.map +0 -1
- package/dist/devices-hap/iosensor.d.ts +0 -42
- package/dist/devices-hap/iosensor.d.ts.map +0 -1
- package/dist/devices-hap/iosensor.js +0 -382
- package/dist/devices-hap/iosensor.js.map +0 -1
- package/dist/devices-hap/lightstrip.d.ts +0 -79
- package/dist/devices-hap/lightstrip.d.ts.map +0 -1
- package/dist/devices-hap/lightstrip.js +0 -797
- package/dist/devices-hap/lightstrip.js.map +0 -1
- package/dist/devices-hap/lock.d.ts +0 -53
- package/dist/devices-hap/lock.d.ts.map +0 -1
- package/dist/devices-hap/lock.js +0 -561
- package/dist/devices-hap/lock.js.map +0 -1
- package/dist/devices-hap/meter.d.ts +0 -37
- package/dist/devices-hap/meter.d.ts.map +0 -1
- package/dist/devices-hap/meter.js +0 -379
- package/dist/devices-hap/meter.js.map +0 -1
- package/dist/devices-hap/meterplus.d.ts +0 -42
- package/dist/devices-hap/meterplus.d.ts.map +0 -1
- package/dist/devices-hap/meterplus.js +0 -384
- package/dist/devices-hap/meterplus.js.map +0 -1
- package/dist/devices-hap/meterpro.d.ts +0 -43
- package/dist/devices-hap/meterpro.d.ts.map +0 -1
- package/dist/devices-hap/meterpro.js +0 -468
- package/dist/devices-hap/meterpro.js.map +0 -1
- package/dist/devices-hap/motion.d.ts +0 -42
- package/dist/devices-hap/motion.d.ts.map +0 -1
- package/dist/devices-hap/motion.js +0 -345
- package/dist/devices-hap/motion.js.map +0 -1
- package/dist/devices-hap/plug.d.ts +0 -49
- package/dist/devices-hap/plug.d.ts.map +0 -1
- package/dist/devices-hap/plug.js +0 -395
- package/dist/devices-hap/plug.js.map +0 -1
- package/dist/devices-hap/relayswitch.d.ts +0 -96
- package/dist/devices-hap/relayswitch.d.ts.map +0 -1
- package/dist/devices-hap/relayswitch.js +0 -642
- package/dist/devices-hap/relayswitch.js.map +0 -1
- package/dist/devices-hap/robotvacuumcleaner.d.ts +0 -54
- package/dist/devices-hap/robotvacuumcleaner.d.ts.map +0 -1
- package/dist/devices-hap/robotvacuumcleaner.js +0 -523
- package/dist/devices-hap/robotvacuumcleaner.js.map +0 -1
- package/dist/devices-hap/waterdetector.d.ts +0 -41
- package/dist/devices-hap/waterdetector.d.ts.map +0 -1
- package/dist/devices-hap/waterdetector.js +0 -356
- package/dist/devices-hap/waterdetector.js.map +0 -1
- package/dist/devices-matter/BaseMatterAccessory.d.ts +0 -63
- package/dist/devices-matter/BaseMatterAccessory.d.ts.map +0 -1
- package/dist/devices-matter/BaseMatterAccessory.js +0 -100
- package/dist/devices-matter/BaseMatterAccessory.js.map +0 -1
- package/dist/devices-matter/ColorLightAccessory.d.ts +0 -20
- package/dist/devices-matter/ColorLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ColorLightAccessory.js +0 -95
- package/dist/devices-matter/ColorLightAccessory.js.map +0 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts +0 -18
- package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ColorTemperatureLightAccessory.js +0 -78
- package/dist/devices-matter/ColorTemperatureLightAccessory.js.map +0 -1
- package/dist/devices-matter/ContactSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/ContactSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ContactSensorAccessory.js +0 -34
- package/dist/devices-matter/ContactSensorAccessory.js.map +0 -1
- package/dist/devices-matter/DimmableLightAccessory.d.ts +0 -58
- package/dist/devices-matter/DimmableLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/DimmableLightAccessory.js +0 -167
- package/dist/devices-matter/DimmableLightAccessory.js.map +0 -1
- package/dist/devices-matter/DoorLockAccessory.d.ts +0 -14
- package/dist/devices-matter/DoorLockAccessory.d.ts.map +0 -1
- package/dist/devices-matter/DoorLockAccessory.js +0 -50
- package/dist/devices-matter/DoorLockAccessory.js.map +0 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.d.ts +0 -21
- package/dist/devices-matter/ExtendedColorLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ExtendedColorLightAccessory.js +0 -107
- package/dist/devices-matter/ExtendedColorLightAccessory.js.map +0 -1
- package/dist/devices-matter/FanAccessory.d.ts +0 -16
- package/dist/devices-matter/FanAccessory.d.ts.map +0 -1
- package/dist/devices-matter/FanAccessory.js +0 -81
- package/dist/devices-matter/FanAccessory.js.map +0 -1
- package/dist/devices-matter/HumiditySensorAccessory.d.ts +0 -12
- package/dist/devices-matter/HumiditySensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/HumiditySensorAccessory.js +0 -34
- package/dist/devices-matter/HumiditySensorAccessory.js.map +0 -1
- package/dist/devices-matter/LeakSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/LeakSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/LeakSensorAccessory.js +0 -33
- package/dist/devices-matter/LeakSensorAccessory.js.map +0 -1
- package/dist/devices-matter/LightSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/LightSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/LightSensorAccessory.js +0 -34
- package/dist/devices-matter/LightSensorAccessory.js.map +0 -1
- package/dist/devices-matter/OccupancySensorAccessory.d.ts +0 -12
- package/dist/devices-matter/OccupancySensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OccupancySensorAccessory.js +0 -39
- package/dist/devices-matter/OccupancySensorAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffLightAccessory.d.ts +0 -38
- package/dist/devices-matter/OnOffLightAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffLightAccessory.js +0 -118
- package/dist/devices-matter/OnOffLightAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffOutletAccessory.d.ts +0 -12
- package/dist/devices-matter/OnOffOutletAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffOutletAccessory.js +0 -40
- package/dist/devices-matter/OnOffOutletAccessory.js.map +0 -1
- package/dist/devices-matter/OnOffSwitchAccessory.d.ts +0 -14
- package/dist/devices-matter/OnOffSwitchAccessory.d.ts.map +0 -1
- package/dist/devices-matter/OnOffSwitchAccessory.js +0 -42
- package/dist/devices-matter/OnOffSwitchAccessory.js.map +0 -1
- package/dist/devices-matter/RoboticVacuumAccessory.d.ts +0 -68
- package/dist/devices-matter/RoboticVacuumAccessory.d.ts.map +0 -1
- package/dist/devices-matter/RoboticVacuumAccessory.js +0 -334
- package/dist/devices-matter/RoboticVacuumAccessory.js.map +0 -1
- package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts +0 -11
- package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts.map +0 -1
- package/dist/devices-matter/SmokeCOAlarmAccessory.js +0 -49
- package/dist/devices-matter/SmokeCOAlarmAccessory.js.map +0 -1
- package/dist/devices-matter/TemperatureSensorAccessory.d.ts +0 -12
- package/dist/devices-matter/TemperatureSensorAccessory.d.ts.map +0 -1
- package/dist/devices-matter/TemperatureSensorAccessory.js +0 -36
- package/dist/devices-matter/TemperatureSensorAccessory.js.map +0 -1
- package/dist/devices-matter/ThermostatAccessory.d.ts +0 -19
- package/dist/devices-matter/ThermostatAccessory.d.ts.map +0 -1
- package/dist/devices-matter/ThermostatAccessory.js +0 -95
- package/dist/devices-matter/ThermostatAccessory.js.map +0 -1
- package/dist/devices-matter/VenetianBlindAccessory.d.ts +0 -19
- package/dist/devices-matter/VenetianBlindAccessory.d.ts.map +0 -1
- package/dist/devices-matter/VenetianBlindAccessory.js +0 -99
- package/dist/devices-matter/VenetianBlindAccessory.js.map +0 -1
- package/dist/devices-matter/WindowBlindAccessory.d.ts +0 -17
- package/dist/devices-matter/WindowBlindAccessory.d.ts.map +0 -1
- package/dist/devices-matter/WindowBlindAccessory.js +0 -80
- package/dist/devices-matter/WindowBlindAccessory.js.map +0 -1
- package/dist/devices-matter/custom/PowerStripAccessory.d.ts +0 -97
- package/dist/devices-matter/custom/PowerStripAccessory.d.ts.map +0 -1
- package/dist/devices-matter/custom/PowerStripAccessory.js +0 -265
- package/dist/devices-matter/custom/PowerStripAccessory.js.map +0 -1
- package/dist/devices-matter/custom/index.d.ts +0 -8
- package/dist/devices-matter/custom/index.d.ts.map +0 -1
- package/dist/devices-matter/custom/index.js +0 -8
- package/dist/devices-matter/custom/index.js.map +0 -1
- package/dist/devices-matter/index.d.ts +0 -29
- package/dist/devices-matter/index.d.ts.map +0 -1
- package/dist/devices-matter/index.js +0 -28
- package/dist/devices-matter/index.js.map +0 -1
- package/dist/index.test.d.ts +0 -2
- package/dist/index.test.d.ts.map +0 -1
- package/dist/index.test.js +0 -14
- package/dist/index.test.js.map +0 -1
- package/dist/irdevice/airconditioner.d.ts +0 -61
- package/dist/irdevice/airconditioner.d.ts.map +0 -1
- package/dist/irdevice/airconditioner.js +0 -472
- package/dist/irdevice/airconditioner.js.map +0 -1
- package/dist/irdevice/airpurifier.d.ts +0 -50
- package/dist/irdevice/airpurifier.d.ts.map +0 -1
- package/dist/irdevice/airpurifier.js +0 -213
- package/dist/irdevice/airpurifier.js.map +0 -1
- package/dist/irdevice/camera.d.ts +0 -32
- package/dist/irdevice/camera.d.ts.map +0 -1
- package/dist/irdevice/camera.js +0 -107
- package/dist/irdevice/camera.js.map +0 -1
- package/dist/irdevice/fan.d.ts +0 -36
- package/dist/irdevice/fan.d.ts.map +0 -1
- package/dist/irdevice/fan.js +0 -200
- package/dist/irdevice/fan.js.map +0 -1
- package/dist/irdevice/irdevice.d.ts +0 -68
- package/dist/irdevice/irdevice.d.ts.map +0 -1
- package/dist/irdevice/irdevice.js +0 -298
- package/dist/irdevice/irdevice.js.map +0 -1
- package/dist/irdevice/light.d.ts +0 -36
- package/dist/irdevice/light.d.ts.map +0 -1
- package/dist/irdevice/light.js +0 -206
- package/dist/irdevice/light.js.map +0 -1
- package/dist/irdevice/other.d.ts +0 -57
- package/dist/irdevice/other.d.ts.map +0 -1
- package/dist/irdevice/other.js +0 -778
- package/dist/irdevice/other.js.map +0 -1
- package/dist/irdevice/tv.d.ts +0 -45
- package/dist/irdevice/tv.d.ts.map +0 -1
- package/dist/irdevice/tv.js +0 -327
- package/dist/irdevice/tv.js.map +0 -1
- package/dist/irdevice/vacuumcleaner.d.ts +0 -28
- package/dist/irdevice/vacuumcleaner.d.ts.map +0 -1
- package/dist/irdevice/vacuumcleaner.js +0 -104
- package/dist/irdevice/vacuumcleaner.js.map +0 -1
- package/dist/irdevice/waterheater.d.ts +0 -30
- package/dist/irdevice/waterheater.d.ts.map +0 -1
- package/dist/irdevice/waterheater.js +0 -105
- package/dist/irdevice/waterheater.js.map +0 -1
- package/dist/platform-hap.d.ts +0 -149
- package/dist/platform-hap.d.ts.map +0 -1
- package/dist/platform-hap.js +0 -2861
- package/dist/platform-hap.js.map +0 -1
- package/dist/platform-matter.d.ts +0 -101
- package/dist/platform-matter.d.ts.map +0 -1
- package/dist/platform-matter.js +0 -896
- package/dist/platform-matter.js.map +0 -1
- package/dist/verifyconfig.test.d.ts +0 -2
- package/dist/verifyconfig.test.d.ts.map +0 -1
- package/dist/verifyconfig.test.js +0 -167
- package/dist/verifyconfig.test.js.map +0 -1
- package/src/custom.d.ts +0 -7
- package/src/devices-hap/airpurifier.ts +0 -563
- package/src/devices-hap/blindtilt.ts +0 -1049
- package/src/devices-hap/bot.ts +0 -900
- package/src/devices-hap/ceilinglight.ts +0 -742
- package/src/devices-hap/colorbulb.ts +0 -904
- package/src/devices-hap/contact.ts +0 -457
- package/src/devices-hap/curtain.ts +0 -944
- package/src/devices-hap/device.ts +0 -811
- package/src/devices-hap/fan.ts +0 -711
- package/src/devices-hap/hub.ts +0 -439
- package/src/devices-hap/humidifier.ts +0 -669
- package/src/devices-hap/iosensor.ts +0 -427
- package/src/devices-hap/lightstrip.ts +0 -836
- package/src/devices-hap/lock.ts +0 -620
- package/src/devices-hap/meter.ts +0 -426
- package/src/devices-hap/meterplus.ts +0 -430
- package/src/devices-hap/meterpro.ts +0 -522
- package/src/devices-hap/motion.ts +0 -390
- package/src/devices-hap/plug.ts +0 -423
- package/src/devices-hap/relayswitch.ts +0 -727
- package/src/devices-hap/robotvacuumcleaner.ts +0 -568
- package/src/devices-hap/waterdetector.ts +0 -400
- package/src/devices-matter/BaseMatterAccessory.ts +0 -131
- package/src/devices-matter/ColorLightAccessory.ts +0 -110
- package/src/devices-matter/ColorTemperatureLightAccessory.ts +0 -92
- package/src/devices-matter/ContactSensorAccessory.ts +0 -41
- package/src/devices-matter/DimmableLightAccessory.ts +0 -192
- package/src/devices-matter/DoorLockAccessory.ts +0 -60
- package/src/devices-matter/ExtendedColorLightAccessory.ts +0 -123
- package/src/devices-matter/FanAccessory.ts +0 -95
- package/src/devices-matter/HumiditySensorAccessory.ts +0 -41
- package/src/devices-matter/LeakSensorAccessory.ts +0 -40
- package/src/devices-matter/LightSensorAccessory.ts +0 -41
- package/src/devices-matter/OccupancySensorAccessory.ts +0 -48
- package/src/devices-matter/OnOffLightAccessory.ts +0 -133
- package/src/devices-matter/OnOffOutletAccessory.ts +0 -46
- package/src/devices-matter/OnOffSwitchAccessory.ts +0 -51
- package/src/devices-matter/RoboticVacuumAccessory.ts +0 -407
- package/src/devices-matter/SmokeCOAlarmAccessory.ts +0 -59
- package/src/devices-matter/TemperatureSensorAccessory.ts +0 -43
- package/src/devices-matter/ThermostatAccessory.ts +0 -110
- package/src/devices-matter/VenetianBlindAccessory.ts +0 -115
- package/src/devices-matter/WindowBlindAccessory.ts +0 -92
- package/src/devices-matter/custom/PowerStripAccessory.ts +0 -309
- package/src/devices-matter/custom/index.ts +0 -8
- package/src/devices-matter/index.ts +0 -29
- package/src/index.test.ts +0 -19
- package/src/irdevice/airconditioner.ts +0 -533
- package/src/irdevice/airpurifier.ts +0 -252
- package/src/irdevice/camera.ts +0 -129
- package/src/irdevice/fan.ts +0 -226
- package/src/irdevice/irdevice.ts +0 -344
- package/src/irdevice/light.ts +0 -246
- package/src/irdevice/other.ts +0 -790
- package/src/irdevice/tv.ts +0 -378
- package/src/irdevice/vacuumcleaner.ts +0 -126
- package/src/irdevice/waterheater.ts +0 -127
- package/src/platform-hap.ts +0 -2997
- package/src/platform-matter.ts +0 -1010
- package/src/verifyconfig.test.ts +0 -197
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Color Temperature Light Accessory Class
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import type { API, Logger, MatterRequests } from 'homebridge'
|
|
6
|
-
|
|
7
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
8
|
-
|
|
9
|
-
export class ColorTemperatureLightAccessory extends BaseMatterAccessory {
|
|
10
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
11
|
-
const serialNumber = opts?.serialNumber ?? 'LIGHT-003'
|
|
12
|
-
const displayName = opts?.displayName ?? 'Colour Temperature Light'
|
|
13
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
14
|
-
const model = opts?.model ?? 'HB-MATTER-LIGHT-COLOUR-TEMP'
|
|
15
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
16
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
17
|
-
|
|
18
|
-
const clusters = opts?.clusters ?? {
|
|
19
|
-
onOff: { onOff: false },
|
|
20
|
-
levelControl: { currentLevel: 127, minLevel: 1, maxLevel: 254 },
|
|
21
|
-
colorControl: {
|
|
22
|
-
colorMode: api.matter.types.ColorControl.ColorMode.ColorTemperatureMireds,
|
|
23
|
-
colorTemperatureMireds: 250,
|
|
24
|
-
colorTempPhysicalMinMireds: 147,
|
|
25
|
-
colorTempPhysicalMaxMireds: 454,
|
|
26
|
-
coupleColorTempToLevelMinMireds: 147,
|
|
27
|
-
},
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
const handlers = opts?.handlers ?? {
|
|
31
|
-
onOff: { on: async () => this.handleOn(), off: async () => this.handleOff() },
|
|
32
|
-
levelControl: { moveToLevelWithOnOff: async (request: MatterRequests.MoveToLevel) => this.handleSetLevel(request) },
|
|
33
|
-
colorControl: { moveToColorTemperatureLogic: async (request: MatterRequests.MoveToColorTemperature) => this.handleSetColorTemperature(request) },
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
super(api, log, {
|
|
37
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
38
|
-
displayName,
|
|
39
|
-
deviceType: api.matter.deviceTypes.ColorTemperatureLight,
|
|
40
|
-
serialNumber,
|
|
41
|
-
manufacturer,
|
|
42
|
-
model,
|
|
43
|
-
firmwareRevision,
|
|
44
|
-
hardwareRevision,
|
|
45
|
-
clusters,
|
|
46
|
-
handlers,
|
|
47
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
48
|
-
})
|
|
49
|
-
|
|
50
|
-
this.logInfo('initialized.')
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
private async handleOn(): Promise<void> {
|
|
54
|
-
this.logInfo('turning on.')
|
|
55
|
-
// TODO: await myLightAPI.turnOn()
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
private async handleOff(): Promise<void> {
|
|
59
|
-
this.logInfo('turning off.')
|
|
60
|
-
// TODO: await myLightAPI.turnOff()
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
private async handleSetLevel(request: MatterRequests.MoveToLevel): Promise<void> {
|
|
64
|
-
this.logInfo(`MoveToLevel request: ${JSON.stringify(request)}`)
|
|
65
|
-
const { level } = request
|
|
66
|
-
const brightnessPercent = Math.round((level / 254) * 100)
|
|
67
|
-
this.logInfo(`setting brightness to ${brightnessPercent}% (level: ${level}).`)
|
|
68
|
-
// TODO: await myLightAPI.setBrightness(brightnessPercent)
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
private async handleSetColorTemperature(request: MatterRequests.MoveToColorTemperature): Promise<void> {
|
|
72
|
-
this.logInfo(`MoveToColorTemperature request: ${JSON.stringify(request)}`)
|
|
73
|
-
const { colorTemperatureMireds, transitionTime } = request
|
|
74
|
-
const kelvin = Math.round(1000000 / colorTemperatureMireds)
|
|
75
|
-
this.logInfo(`setting color temp to ${kelvin}k (${colorTemperatureMireds} mireds) with transitionTime=${transitionTime}.`)
|
|
76
|
-
// TODO: await myLightAPI.setColorTemperature(kelvin, transitionTime)
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
public updateOnOffState(isOn: boolean): void {
|
|
80
|
-
this.updateState(this.api.matter.clusterNames.OnOff, { onOff: isOn })
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
public updateBrightness(percent: number): void {
|
|
84
|
-
const matterLevel = Math.max(1, Math.round((percent / 100) * 254))
|
|
85
|
-
this.updateState(this.api.matter.clusterNames.LevelControl, { currentLevel: matterLevel })
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
public updateColorTemperature(kelvin: number): void {
|
|
89
|
-
const mireds = Math.round(1000000 / kelvin)
|
|
90
|
-
this.updateState(this.api.matter.clusterNames.ColorControl, { colorTemperatureMireds: mireds })
|
|
91
|
-
}
|
|
92
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Contact Sensor Accessory Class
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import type { API, Logger } from 'homebridge'
|
|
6
|
-
|
|
7
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
8
|
-
|
|
9
|
-
export class ContactSensorAccessory extends BaseMatterAccessory {
|
|
10
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
11
|
-
const serialNumber = opts?.serialNumber ?? 'SENSOR-001'
|
|
12
|
-
const displayName = opts?.displayName ?? 'Contact Sensor'
|
|
13
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
14
|
-
const model = opts?.model ?? 'HB-MATTER-SENSOR-CONTACT'
|
|
15
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
16
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
17
|
-
|
|
18
|
-
const clusters = opts?.clusters ?? { booleanState: { stateValue: true } }
|
|
19
|
-
|
|
20
|
-
super(api, log, {
|
|
21
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
22
|
-
displayName,
|
|
23
|
-
deviceType: api.matter.deviceTypes.ContactSensor,
|
|
24
|
-
serialNumber,
|
|
25
|
-
manufacturer,
|
|
26
|
-
model,
|
|
27
|
-
firmwareRevision,
|
|
28
|
-
hardwareRevision,
|
|
29
|
-
clusters,
|
|
30
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
31
|
-
})
|
|
32
|
-
|
|
33
|
-
this.logInfo('initialized.')
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
public updateContactState(isOpen: boolean): void {
|
|
37
|
-
// Matter BooleanState: false = open/triggered, true = closed/normal (inverted!)
|
|
38
|
-
this.updateState(this.api.matter.clusterNames.BooleanState, { stateValue: !isOpen })
|
|
39
|
-
this.logInfo(`contact state: ${isOpen ? 'OPEN' : 'CLOSED'}.`)
|
|
40
|
-
}
|
|
41
|
-
}
|
|
@@ -1,192 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Dimmable Light Accessory Class
|
|
3
|
-
*
|
|
4
|
-
* Example of a more complex device with multiple clusters.
|
|
5
|
-
* Shows how to handle devices with on/off + level control.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import type { API, Logger, MatterRequests } from 'homebridge'
|
|
9
|
-
|
|
10
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Dimmable Light Device Class
|
|
14
|
-
*
|
|
15
|
-
* Demonstrates:
|
|
16
|
-
* - Multiple clusters (OnOff + LevelControl)
|
|
17
|
-
* - Type-safe request handlers
|
|
18
|
-
* - Value conversion (Matter level ↔ percentage)
|
|
19
|
-
* - Custom public methods for external control
|
|
20
|
-
*/
|
|
21
|
-
export class DimmableLightAccessory extends BaseMatterAccessory {
|
|
22
|
-
// Track current state
|
|
23
|
-
private currentLevel: number = 127 // 50% brightness
|
|
24
|
-
|
|
25
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
26
|
-
const serialNumber = opts?.serialNumber ?? 'LIGHT-002'
|
|
27
|
-
const displayName = opts?.displayName ?? 'Dimmable Light'
|
|
28
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
29
|
-
const model = opts?.model ?? 'HB-MATTER-LIGHT-DIMMABLE'
|
|
30
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
31
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
32
|
-
|
|
33
|
-
const clusters = opts?.clusters ?? {
|
|
34
|
-
onOff: { onOff: false },
|
|
35
|
-
levelControl: { currentLevel: 127, minLevel: 1, maxLevel: 254 },
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const handlers = opts?.handlers ?? {
|
|
39
|
-
onOff: {
|
|
40
|
-
on: async () => this.handleOn(),
|
|
41
|
-
off: async () => this.handleOff(),
|
|
42
|
-
},
|
|
43
|
-
levelControl: {
|
|
44
|
-
moveToLevelWithOnOff: async (request: MatterRequests.MoveToLevel) => this.handleSetLevel(request),
|
|
45
|
-
},
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
super(api, log, {
|
|
49
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
50
|
-
displayName,
|
|
51
|
-
deviceType: api.matter.deviceTypes.DimmableLight,
|
|
52
|
-
serialNumber,
|
|
53
|
-
manufacturer,
|
|
54
|
-
model,
|
|
55
|
-
firmwareRevision,
|
|
56
|
-
hardwareRevision,
|
|
57
|
-
clusters,
|
|
58
|
-
handlers,
|
|
59
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
60
|
-
})
|
|
61
|
-
|
|
62
|
-
this.logInfo('initialized.')
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* Handle the "on" command
|
|
67
|
-
*/
|
|
68
|
-
private async handleOn(): Promise<void> {
|
|
69
|
-
this.logInfo('turning on.')
|
|
70
|
-
|
|
71
|
-
try {
|
|
72
|
-
// TODO: Control your physical device
|
|
73
|
-
// await myLightAPI.turnOn()
|
|
74
|
-
|
|
75
|
-
this.logInfo('physical device turned on.')
|
|
76
|
-
} catch (error) {
|
|
77
|
-
this.logError('failed to turn on:', error)
|
|
78
|
-
throw error
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
/**
|
|
83
|
-
* Handle the "off" command
|
|
84
|
-
*/
|
|
85
|
-
private async handleOff(): Promise<void> {
|
|
86
|
-
this.logInfo('turning off.')
|
|
87
|
-
|
|
88
|
-
try {
|
|
89
|
-
// TODO: Control your physical device
|
|
90
|
-
// await myLightAPI.turnOff()
|
|
91
|
-
|
|
92
|
-
this.logInfo('physical device turned off.')
|
|
93
|
-
} catch (error) {
|
|
94
|
-
this.logError('failed to turn off:', error)
|
|
95
|
-
throw error
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
/**
|
|
100
|
-
* Handle brightness level changes
|
|
101
|
-
*/
|
|
102
|
-
private async handleSetLevel(request: MatterRequests.MoveToLevel): Promise<void> {
|
|
103
|
-
this.logInfo(`MoveToLevel request: ${JSON.stringify(request)}`)
|
|
104
|
-
const { level, transitionTime } = request
|
|
105
|
-
|
|
106
|
-
// Convert Matter level (1-254) to percentage (0-100%)
|
|
107
|
-
const brightnessPercent = Math.round((level / 254) * 100)
|
|
108
|
-
this.currentLevel = level
|
|
109
|
-
|
|
110
|
-
this.logInfo(`setting brightness to ${brightnessPercent}% (level: ${level}), transitionTime: ${transitionTime}.`)
|
|
111
|
-
|
|
112
|
-
try {
|
|
113
|
-
// TODO: Control your physical device
|
|
114
|
-
// await myLightAPI.setBrightness(brightnessPercent, transitionTime)
|
|
115
|
-
|
|
116
|
-
this.logInfo(`physical device brightness set to ${brightnessPercent}%.`)
|
|
117
|
-
} catch (error) {
|
|
118
|
-
this.logError('Failed to set brightness:', error)
|
|
119
|
-
throw error
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
/**
|
|
124
|
-
* Update on/off state from external source
|
|
125
|
-
*/
|
|
126
|
-
public updateOnOffState(isOn: boolean): void {
|
|
127
|
-
this.updateState(this.api.matter.clusterNames.OnOff, { onOff: isOn })
|
|
128
|
-
this.logInfo(`state synced: ${isOn ? 'ON' : 'OFF'}.`)
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
/**
|
|
132
|
-
* Update brightness level from external source
|
|
133
|
-
* @param percent - Brightness percentage (0-100)
|
|
134
|
-
*/
|
|
135
|
-
public updateBrightness(percent: number): void {
|
|
136
|
-
// Validate input
|
|
137
|
-
if (percent < 0 || percent > 100) {
|
|
138
|
-
this.logWarn(`Invalid brightness percentage: ${percent}. Must be 0-100.`)
|
|
139
|
-
return
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
// Convert percent to Matter level (1-254)
|
|
143
|
-
const matterLevel = Math.max(1, Math.round((percent / 100) * 254))
|
|
144
|
-
this.currentLevel = matterLevel
|
|
145
|
-
|
|
146
|
-
this.updateState(this.api.matter.clusterNames.LevelControl, {
|
|
147
|
-
currentLevel: matterLevel,
|
|
148
|
-
})
|
|
149
|
-
|
|
150
|
-
this.logInfo(`brightness synced: ${percent}% (level: ${matterLevel}).`)
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
/**
|
|
154
|
-
* Get current brightness as percentage
|
|
155
|
-
*/
|
|
156
|
-
public getBrightness(): number {
|
|
157
|
-
return Math.round((this.currentLevel / 254) * 100)
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
/**
|
|
161
|
-
* Set brightness and power state together
|
|
162
|
-
* Useful for syncing complete state from external source
|
|
163
|
-
*/
|
|
164
|
-
public updateFullState(isOn: boolean, percent: number): void {
|
|
165
|
-
this.updateOnOffState(isOn)
|
|
166
|
-
if (isOn) {
|
|
167
|
-
this.updateBrightness(percent)
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
/**
|
|
172
|
-
* Example monitoring setup
|
|
173
|
-
*/
|
|
174
|
-
public startMonitoring(): void {
|
|
175
|
-
// Example: MQTT listener
|
|
176
|
-
// mqttClient.on('message', (topic, message) => {
|
|
177
|
-
// const { state, brightness } = JSON.parse(message.toString())
|
|
178
|
-
// this.updateFullState(state === 'ON', brightness)
|
|
179
|
-
// })
|
|
180
|
-
|
|
181
|
-
// Example: Polling
|
|
182
|
-
// setInterval(async () => {
|
|
183
|
-
// try {
|
|
184
|
-
// const response = await fetch('https://api.mydevice.com/light/state')
|
|
185
|
-
// const data = await response.json()
|
|
186
|
-
// this.updateFullState(data.power === 'on', data.brightness)
|
|
187
|
-
// } catch (error) {
|
|
188
|
-
// this.logError('Polling error:', error)
|
|
189
|
-
// }
|
|
190
|
-
// }, 5000)
|
|
191
|
-
}
|
|
192
|
-
}
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Door Lock Accessory Class
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import type { API, Logger } from 'homebridge'
|
|
6
|
-
|
|
7
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
8
|
-
|
|
9
|
-
export class DoorLockAccessory extends BaseMatterAccessory {
|
|
10
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
11
|
-
const serialNumber = opts?.serialNumber ?? 'LOCK-001'
|
|
12
|
-
const displayName = opts?.displayName ?? 'Door Lock'
|
|
13
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
14
|
-
const model = opts?.model ?? 'HB-MATTER-LOCK-DOOR'
|
|
15
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
16
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
17
|
-
|
|
18
|
-
const clusters = opts?.clusters ?? {
|
|
19
|
-
doorLock: {
|
|
20
|
-
lockState: api.matter.types.DoorLock.LockState.Unlocked,
|
|
21
|
-
lockType: api.matter.types.DoorLock.LockType.DeadBolt,
|
|
22
|
-
actuatorEnabled: true,
|
|
23
|
-
operatingMode: api.matter.types.DoorLock.OperatingMode.Normal,
|
|
24
|
-
},
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const handlers = opts?.handlers ?? { doorLock: { lockDoor: async () => this.handleLock(), unlockDoor: async () => this.handleUnlock() } }
|
|
28
|
-
|
|
29
|
-
super(api, log, {
|
|
30
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
31
|
-
displayName,
|
|
32
|
-
deviceType: api.matter.deviceTypes.DoorLock,
|
|
33
|
-
serialNumber,
|
|
34
|
-
manufacturer,
|
|
35
|
-
model,
|
|
36
|
-
firmwareRevision,
|
|
37
|
-
hardwareRevision,
|
|
38
|
-
clusters,
|
|
39
|
-
handlers,
|
|
40
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
41
|
-
})
|
|
42
|
-
|
|
43
|
-
this.logInfo('initialized.')
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
private async handleLock(): Promise<void> {
|
|
47
|
-
this.logInfo('locked.')
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
private async handleUnlock(): Promise<void> {
|
|
51
|
-
this.logInfo('unlocked.')
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
public updateLockState(state: 0 | 1 | 2): void {
|
|
55
|
-
// 0 = Not fully locked, 1 = Locked, 2 = Unlocked
|
|
56
|
-
this.updateState('doorLock', { lockState: state })
|
|
57
|
-
const stateStr = ['Not Fully Locked', 'Locked', 'Unlocked'][state]
|
|
58
|
-
this.logInfo(`lock state: ${stateStr}.`)
|
|
59
|
-
}
|
|
60
|
-
}
|
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Extended Color Light Accessory Class (HS+CCT)
|
|
3
|
-
* Hue, Saturation, and Color Temperature control
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
import type { API, Logger, MatterRequests } from 'homebridge'
|
|
7
|
-
|
|
8
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
9
|
-
|
|
10
|
-
export class ExtendedColorLightAccessory extends BaseMatterAccessory {
|
|
11
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
12
|
-
const serialNumber = opts?.serialNumber ?? 'LIGHT-005'
|
|
13
|
-
const displayName = opts?.displayName ?? 'Extended Colour Light (HS+CCT)'
|
|
14
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
15
|
-
const model = opts?.model ?? 'HB-MATTER-LIGHT-EXTENDED-COLOUR'
|
|
16
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
17
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
18
|
-
|
|
19
|
-
const clusters = opts?.clusters ?? {
|
|
20
|
-
onOff: { onOff: false },
|
|
21
|
-
levelControl: { currentLevel: 127, minLevel: 1, maxLevel: 254 },
|
|
22
|
-
colorControl: {
|
|
23
|
-
colorMode: api.matter.types.ColorControl.ColorMode.CurrentHueAndCurrentSaturation,
|
|
24
|
-
currentHue: 0,
|
|
25
|
-
currentSaturation: 254,
|
|
26
|
-
currentX: 41942,
|
|
27
|
-
currentY: 21626,
|
|
28
|
-
colorTemperatureMireds: 250,
|
|
29
|
-
colorTempPhysicalMinMireds: 147,
|
|
30
|
-
colorTempPhysicalMaxMireds: 454,
|
|
31
|
-
coupleColorTempToLevelMinMireds: 147,
|
|
32
|
-
},
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const handlers = opts?.handlers ?? {
|
|
36
|
-
onOff: { on: async () => this.handleOn(), off: async () => this.handleOff() },
|
|
37
|
-
levelControl: { moveToLevelWithOnOff: async (request: MatterRequests.MoveToLevel) => this.handleSetLevel(request) },
|
|
38
|
-
colorControl: {
|
|
39
|
-
moveToColorLogic: async (request: MatterRequests.MoveToColor) => this.handleSetColor(request),
|
|
40
|
-
moveToHueAndSaturationLogic: async (request: MatterRequests.MoveToHueAndSaturation) => this.handleSetHueSaturation(request),
|
|
41
|
-
moveToColorTemperatureLogic: async (request: MatterRequests.MoveToColorTemperature) => this.handleSetColorTemperature(request),
|
|
42
|
-
},
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
super(api, log, {
|
|
46
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
47
|
-
displayName,
|
|
48
|
-
deviceType: api.matter.deviceTypes.ExtendedColorLight,
|
|
49
|
-
serialNumber,
|
|
50
|
-
manufacturer,
|
|
51
|
-
model,
|
|
52
|
-
firmwareRevision,
|
|
53
|
-
hardwareRevision,
|
|
54
|
-
clusters,
|
|
55
|
-
handlers,
|
|
56
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
57
|
-
})
|
|
58
|
-
|
|
59
|
-
this.logInfo('initialized.')
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
private async handleOn(): Promise<void> {
|
|
63
|
-
this.logInfo('turning on.')
|
|
64
|
-
// TODO: await myLightAPI.turnOn()
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
private async handleOff(): Promise<void> {
|
|
68
|
-
this.logInfo('turning off.')
|
|
69
|
-
// TODO: await myLightAPI.turnOff()
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
private async handleSetLevel(request: MatterRequests.MoveToLevel): Promise<void> {
|
|
73
|
-
this.logInfo(`MoveToLevel request: ${JSON.stringify(request)}`)
|
|
74
|
-
const { level } = request
|
|
75
|
-
const brightnessPercent = Math.round((level / 254) * 100)
|
|
76
|
-
this.logInfo(`setting brightness to ${brightnessPercent}%.`)
|
|
77
|
-
// TODO: await myLightAPI.setBrightness(brightnessPercent)
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
private async handleSetColor(request: MatterRequests.MoveToColor): Promise<void> {
|
|
81
|
-
this.logInfo(`MoveToColor request: ${JSON.stringify(request)}`)
|
|
82
|
-
const { colorX, colorY, transitionTime } = request
|
|
83
|
-
const xFloat = (colorX / 65535).toFixed(4)
|
|
84
|
-
const yFloat = (colorY / 65535).toFixed(4)
|
|
85
|
-
this.logInfo(`setting xy color to (${xFloat}, ${yFloat}), ${transitionTime}ms.`)
|
|
86
|
-
// TODO: await myLightAPI.setXY(xFloat, yFloat, transitionTime)
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
private async handleSetHueSaturation(request: MatterRequests.MoveToHueAndSaturation): Promise<void> {
|
|
90
|
-
this.logInfo(`MoveToHueAndSaturation request: ${JSON.stringify(request)}`)
|
|
91
|
-
const { hue, saturation, transitionTime } = request
|
|
92
|
-
const hueDegrees = Math.round((hue / 254) * 360)
|
|
93
|
-
const saturationPercent = Math.round((saturation / 254) * 100)
|
|
94
|
-
this.logInfo(`setting color to ${hueDegrees}°, ${saturationPercent}%, ${transitionTime}ms.`)
|
|
95
|
-
// TODO: await myLightAPI.setColor(hueDegrees, saturationPercent, transitionTime)
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
private async handleSetColorTemperature(request: MatterRequests.MoveToColorTemperature): Promise<void> {
|
|
99
|
-
this.logInfo(`MoveToColorTemperature request: ${JSON.stringify(request)}`)
|
|
100
|
-
const { colorTemperatureMireds, transitionTime } = request
|
|
101
|
-
const kelvin = Math.round(1000000 / colorTemperatureMireds)
|
|
102
|
-
this.logInfo(`setting color temp to ${kelvin}k, ${transitionTime}ms.`)
|
|
103
|
-
// TODO: await myLightAPI.setColorTemperature(kelvin, transitionTime)
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
public updateOnOffState(isOn: boolean): void {
|
|
107
|
-
this.updateState(this.api.matter.clusterNames.OnOff, { onOff: isOn })
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
public updateBrightness(percent: number): void {
|
|
111
|
-
const matterLevel = Math.max(1, Math.round((percent / 100) * 254))
|
|
112
|
-
this.updateState(this.api.matter.clusterNames.LevelControl, { currentLevel: matterLevel })
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
public updateHueSaturation(hue: number, saturation: number): void {
|
|
116
|
-
const matterHue = Math.round((hue / 360) * 254)
|
|
117
|
-
const matterSat = Math.round((saturation / 100) * 254)
|
|
118
|
-
this.updateState(this.api.matter.clusterNames.ColorControl, {
|
|
119
|
-
currentHue: matterHue,
|
|
120
|
-
currentSaturation: matterSat,
|
|
121
|
-
})
|
|
122
|
-
}
|
|
123
|
-
}
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Fan Accessory Class
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import type { API, Logger, MatterRequests } from 'homebridge'
|
|
6
|
-
|
|
7
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
8
|
-
|
|
9
|
-
export class FanAccessory extends BaseMatterAccessory {
|
|
10
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
11
|
-
const serialNumber = opts?.serialNumber ?? 'FAN-001'
|
|
12
|
-
const displayName = opts?.displayName ?? 'Fan'
|
|
13
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
14
|
-
const model = opts?.model ?? 'HB-MATTER-FAN'
|
|
15
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
16
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
17
|
-
|
|
18
|
-
const clusters = opts?.clusters ?? {
|
|
19
|
-
fanControl: {
|
|
20
|
-
fanMode: api.matter.types.FanControl.FanMode.Off,
|
|
21
|
-
fanModeSequence: api.matter.types.FanControl.FanModeSequence.OffLowMedHigh,
|
|
22
|
-
percentSetting: 0,
|
|
23
|
-
percentCurrent: 0,
|
|
24
|
-
},
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const handlers = opts?.handlers ?? {
|
|
28
|
-
fanControl: {
|
|
29
|
-
step: async (request: MatterRequests.FanStep) => this.handleStep(request),
|
|
30
|
-
fanModeChange: async (request: { fanMode: number, oldFanMode: number }) => this.handleFanModeChange(request),
|
|
31
|
-
percentSettingChange: async (request: { percentSetting: number | null, oldPercentSetting: number | null }) => this.handlePercentSettingChange(request),
|
|
32
|
-
},
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
super(api, log, {
|
|
36
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
37
|
-
displayName,
|
|
38
|
-
deviceType: api.matter.deviceTypes.Fan,
|
|
39
|
-
serialNumber,
|
|
40
|
-
manufacturer,
|
|
41
|
-
model,
|
|
42
|
-
firmwareRevision,
|
|
43
|
-
hardwareRevision,
|
|
44
|
-
clusters,
|
|
45
|
-
handlers,
|
|
46
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
47
|
-
})
|
|
48
|
-
|
|
49
|
-
this.logInfo('initialized.')
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
private async handleStep(request: MatterRequests.FanStep): Promise<void> {
|
|
53
|
-
this.logInfo(`FanStep request: ${JSON.stringify(request)}`)
|
|
54
|
-
const { direction, wrap, lowestOff } = request
|
|
55
|
-
const dirStr = direction === 0 ? 'increase' : 'decrease'
|
|
56
|
-
this.logInfo(`step ${dirStr} (wrap: ${wrap}, lowestoff: ${lowestOff}).`)
|
|
57
|
-
// TODO: await myFanAPI.step(direction, wrap, lowestOff)
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
private async handleFanModeChange(request: { fanMode: number, oldFanMode: number }): Promise<void> {
|
|
61
|
-
this.logInfo(`FanMode change: ${JSON.stringify(request)}`)
|
|
62
|
-
const modeNames = ['Off', 'Low', 'Medium', 'High', 'On', 'Auto', 'Smart']
|
|
63
|
-
const modeName = modeNames[request.fanMode] || `Unknown (${request.fanMode})`
|
|
64
|
-
this.logInfo(`fan mode changed to: ${modeName}.`)
|
|
65
|
-
// TODO: await myFanAPI.setMode(request.fanMode)
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
private async handlePercentSettingChange(request: { percentSetting: number | null, oldPercentSetting: number | null }): Promise<void> {
|
|
69
|
-
this.logInfo(`PercentSetting change: ${JSON.stringify(request)}`)
|
|
70
|
-
const percent = request.percentSetting ?? 0
|
|
71
|
-
const isOff = percent === 0
|
|
72
|
-
const wasOff = (request.oldPercentSetting ?? 0) === 0
|
|
73
|
-
|
|
74
|
-
if (isOff !== wasOff) {
|
|
75
|
-
this.logInfo(`fan turned ${isOff ? 'off' : 'on'}.`)
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
if (!isOff) {
|
|
79
|
-
this.logInfo(`fan speed changed to: ${percent}%.`)
|
|
80
|
-
}
|
|
81
|
-
// TODO: await myFanAPI.setSpeed(percent)
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
public updateFanMode(mode: number): void {
|
|
85
|
-
this.updateState(this.api.matter.clusterNames.FanControl, { fanMode: mode })
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
public updateFanSpeed(percent: number): void {
|
|
89
|
-
this.updateState(this.api.matter.clusterNames.FanControl, {
|
|
90
|
-
percentSetting: percent,
|
|
91
|
-
percentCurrent: percent,
|
|
92
|
-
})
|
|
93
|
-
this.logInfo(`fan speed: ${percent}%.`)
|
|
94
|
-
}
|
|
95
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Humidity Sensor Accessory Class
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import type { API, Logger } from 'homebridge'
|
|
6
|
-
|
|
7
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
8
|
-
|
|
9
|
-
export class HumiditySensorAccessory extends BaseMatterAccessory {
|
|
10
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
11
|
-
const serialNumber = opts?.serialNumber ?? 'SENSOR-005'
|
|
12
|
-
const displayName = opts?.displayName ?? 'Humidity Sensor'
|
|
13
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
14
|
-
const model = opts?.model ?? 'HB-MATTER-SENSOR-HUMIDITY'
|
|
15
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
16
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
17
|
-
|
|
18
|
-
const clusters = opts?.clusters ?? { relativeHumidityMeasurement: { measuredValue: 5500, minMeasuredValue: 0, maxMeasuredValue: 10000 } }
|
|
19
|
-
|
|
20
|
-
super(api, log, {
|
|
21
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
22
|
-
displayName,
|
|
23
|
-
deviceType: api.matter.deviceTypes.HumiditySensor,
|
|
24
|
-
serialNumber,
|
|
25
|
-
manufacturer,
|
|
26
|
-
model,
|
|
27
|
-
firmwareRevision,
|
|
28
|
-
hardwareRevision,
|
|
29
|
-
clusters,
|
|
30
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
31
|
-
})
|
|
32
|
-
|
|
33
|
-
this.logInfo('initialized.')
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
public updateHumidity(percent: number): void {
|
|
37
|
-
const value = Math.round(percent * 100) // convert to hundredths
|
|
38
|
-
this.updateState('relativeHumidityMeasurement', { measuredValue: value })
|
|
39
|
-
this.logInfo(`humidity: ${percent}%.`)
|
|
40
|
-
}
|
|
41
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Leak Sensor Accessory Class
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import type { API, Logger } from 'homebridge'
|
|
6
|
-
|
|
7
|
-
import { BaseMatterAccessory } from './BaseMatterAccessory.js'
|
|
8
|
-
|
|
9
|
-
export class LeakSensorAccessory extends BaseMatterAccessory {
|
|
10
|
-
constructor(api: API, log: Logger, opts?: Partial<import('./BaseMatterAccessory').BaseMatterAccessoryConfig & { deviceId?: string }>) {
|
|
11
|
-
const serialNumber = opts?.serialNumber ?? 'SENSOR-007'
|
|
12
|
-
const displayName = opts?.displayName ?? 'Leak Sensor'
|
|
13
|
-
const manufacturer = opts?.manufacturer ?? 'Homebridge Matter'
|
|
14
|
-
const model = opts?.model ?? 'HB-MATTER-SENSOR-LEAK'
|
|
15
|
-
const firmwareRevision = opts?.firmwareRevision ?? '2.0.0'
|
|
16
|
-
const hardwareRevision = opts?.hardwareRevision ?? '1.0.0'
|
|
17
|
-
|
|
18
|
-
const clusters = opts?.clusters ?? { booleanState: { stateValue: false } }
|
|
19
|
-
|
|
20
|
-
super(api, log, {
|
|
21
|
-
uuid: opts?.uuid ?? api.matter.uuid.generate(serialNumber),
|
|
22
|
-
displayName,
|
|
23
|
-
deviceType: api.matter.deviceTypes.LeakSensor,
|
|
24
|
-
serialNumber,
|
|
25
|
-
manufacturer,
|
|
26
|
-
model,
|
|
27
|
-
firmwareRevision,
|
|
28
|
-
hardwareRevision,
|
|
29
|
-
clusters,
|
|
30
|
-
context: { deviceId: opts?.deviceId, ...(opts?.context ?? {}) },
|
|
31
|
-
})
|
|
32
|
-
|
|
33
|
-
this.logInfo('initialized.')
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
public updateLeakState(leakDetected: boolean): void {
|
|
37
|
-
this.updateState(this.api.matter.clusterNames.BooleanState, { stateValue: leakDetected })
|
|
38
|
-
this.logInfo(`leak: ${leakDetected ? 'detected' : 'none'}.`)
|
|
39
|
-
}
|
|
40
|
-
}
|