@switchbot/homebridge-switchbot 5.0.0-beta.70 → 5.0.0-beta.72

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.
Files changed (534) hide show
  1. package/.github/ISSUE_TEMPLATE/e2e-verification.md +36 -0
  2. package/.github/workflows/ci.yml +61 -0
  3. package/.github/workflows/manual-e2e.yml +103 -0
  4. package/CHANGELOG.md +20 -0
  5. package/E2E-VERIFICATION.md +121 -0
  6. package/MIGRATION.md +44 -0
  7. package/README.md +11 -0
  8. package/config.schema.json +99 -1940
  9. package/dist/deviceFactory.d.ts +13 -0
  10. package/dist/deviceFactory.d.ts.map +1 -0
  11. package/dist/deviceFactory.js +81 -0
  12. package/dist/deviceFactory.js.map +1 -0
  13. package/dist/devices/deviceBase.d.ts +50 -0
  14. package/dist/devices/deviceBase.d.ts.map +1 -0
  15. package/dist/devices/deviceBase.js +119 -0
  16. package/dist/devices/deviceBase.js.map +1 -0
  17. package/dist/devices/genericDevice.d.ts +283 -0
  18. package/dist/devices/genericDevice.d.ts.map +1 -0
  19. package/dist/devices/genericDevice.js +1035 -0
  20. package/dist/devices/genericDevice.js.map +1 -0
  21. package/dist/homebridge-ui/public/index.html +72 -440
  22. package/dist/homebridge-ui/server.d.ts +3 -1
  23. package/dist/homebridge-ui/server.d.ts.map +1 -1
  24. package/dist/homebridge-ui/server.js +47 -10
  25. package/dist/homebridge-ui/server.js.map +1 -1
  26. package/dist/index.d.ts.map +1 -1
  27. package/dist/index.js +1 -3
  28. package/dist/index.js.map +1 -1
  29. package/dist/platform.d.ts +27 -0
  30. package/dist/platform.d.ts.map +1 -0
  31. package/dist/platform.js +404 -0
  32. package/dist/platform.js.map +1 -0
  33. package/dist/settings.d.ts +10 -317
  34. package/dist/settings.d.ts.map +1 -1
  35. package/dist/settings.js +5 -30
  36. package/dist/settings.js.map +1 -1
  37. package/dist/switchbotClient.d.ts +32 -0
  38. package/dist/switchbotClient.d.ts.map +1 -0
  39. package/dist/switchbotClient.js +259 -0
  40. package/dist/switchbotClient.js.map +1 -0
  41. package/dist/utils.d.ts +36 -248
  42. package/dist/utils.d.ts.map +1 -1
  43. package/dist/utils.js +38 -1367
  44. package/dist/utils.js.map +1 -1
  45. package/docs/assets/icons.js +1 -1
  46. package/docs/assets/icons.svg +1 -1
  47. package/docs/assets/style.css +3 -3
  48. package/docs/index.html +50 -15
  49. package/docs/variables/default.html +1 -1
  50. package/package.json +19 -18
  51. package/scripts/e2e/README.md +25 -0
  52. package/scripts/e2e/curtain-e2e.sh +70 -0
  53. package/scripts/e2e/fan-e2e.sh +75 -0
  54. package/scripts/e2e/light-advanced-e2e.sh +97 -0
  55. package/scripts/e2e/light-e2e.sh +75 -0
  56. package/scripts/e2e/list-accessories.sh +19 -0
  57. package/scripts/e2e/lock-e2e.sh +65 -0
  58. package/scripts/generate-matter-maps.js +60 -0
  59. package/scripts/run-e2e-local.sh +14 -0
  60. package/src/deviceFactory.ts +122 -0
  61. package/src/devices/deviceBase.ts +141 -0
  62. package/src/devices/genericDevice.ts +965 -0
  63. package/src/homebridge-ui/public/index.html +72 -440
  64. package/src/homebridge-ui/server.ts +52 -10
  65. package/src/index.ts +1 -3
  66. package/src/platform.ts +395 -0
  67. package/src/settings.ts +12 -352
  68. package/src/switchbotClient.ts +266 -0
  69. package/src/utils.ts +47 -1456
  70. package/test/accessory-restore.spec.ts +73 -0
  71. package/test/device-mapping.spec.ts +37 -0
  72. package/test/deviceFactory.spec.ts +18 -0
  73. package/test/e2e/run-e2e.spec.ts +50 -0
  74. package/test/fan-swing.spec.ts +29 -0
  75. package/test/helpers/matter-harness.ts +53 -0
  76. package/test/lock-users.spec.ts +44 -0
  77. package/test/matter-childbridge.spec.ts +55 -0
  78. package/test/matter-descriptors.spec.ts +97 -0
  79. package/test/matter-device-state.spec.ts +101 -0
  80. package/test/matter-integration.spec.ts +70 -0
  81. package/test/platform.integration.spec.ts +55 -0
  82. package/test/switchbot-client-debounce.spec.ts +131 -0
  83. package/test/switchbot-client-openapi.spec.ts +56 -0
  84. package/test/switchbotClient.spec.ts +10 -0
  85. package/test/utils.spec.ts +20 -0
  86. package/vitest.config.ts +7 -0
  87. package/coverage/base.css +0 -224
  88. package/coverage/block-navigation.js +0 -87
  89. package/coverage/clover.xml +0 -15847
  90. package/coverage/coverage-final.json +0 -42
  91. package/coverage/docs/assets/dmt/dmt-component-data.js.html +0 -85
  92. package/coverage/docs/assets/dmt/dmt-components.js.html +0 -286
  93. package/coverage/docs/assets/dmt/index.html +0 -131
  94. package/coverage/docs/assets/hierarchy.js.html +0 -85
  95. package/coverage/docs/assets/icons.js.html +0 -136
  96. package/coverage/docs/assets/index.html +0 -146
  97. package/coverage/docs/assets/main.js.html +0 -265
  98. package/coverage/favicon.png +0 -0
  99. package/coverage/index.html +0 -191
  100. package/coverage/prettify.css +0 -1
  101. package/coverage/prettify.js +0 -2
  102. package/coverage/sort-arrow-sprite.png +0 -0
  103. package/coverage/sorter.js +0 -196
  104. package/coverage/src/device/blindtilt.ts.html +0 -3238
  105. package/coverage/src/device/bot.ts.html +0 -2803
  106. package/coverage/src/device/ceilinglight.ts.html +0 -2338
  107. package/coverage/src/device/colorbulb.ts.html +0 -2824
  108. package/coverage/src/device/contact.ts.html +0 -1465
  109. package/coverage/src/device/curtain.ts.html +0 -2869
  110. package/coverage/src/device/device.ts.html +0 -2500
  111. package/coverage/src/device/fan.ts.html +0 -2242
  112. package/coverage/src/device/hub.ts.html +0 -1408
  113. package/coverage/src/device/humidifier.ts.html +0 -2116
  114. package/coverage/src/device/index.html +0 -416
  115. package/coverage/src/device/iosensor.ts.html +0 -1375
  116. package/coverage/src/device/lightstrip.ts.html +0 -2617
  117. package/coverage/src/device/lock.ts.html +0 -1963
  118. package/coverage/src/device/meter.ts.html +0 -1372
  119. package/coverage/src/device/meterplus.ts.html +0 -1384
  120. package/coverage/src/device/meterpro.ts.html +0 -1618
  121. package/coverage/src/device/motion.ts.html +0 -1264
  122. package/coverage/src/device/plug.ts.html +0 -1372
  123. package/coverage/src/device/relayswitch.ts.html +0 -2284
  124. package/coverage/src/device/robotvacuumcleaner.ts.html +0 -1810
  125. package/coverage/src/device/waterdetector.ts.html +0 -1294
  126. package/coverage/src/homebridge-ui/index.html +0 -116
  127. package/coverage/src/homebridge-ui/server.ts.html +0 -229
  128. package/coverage/src/index.html +0 -161
  129. package/coverage/src/index.ts.html +0 -124
  130. package/coverage/src/irdevice/airconditioner.ts.html +0 -1687
  131. package/coverage/src/irdevice/airpurifier.ts.html +0 -844
  132. package/coverage/src/irdevice/camera.ts.html +0 -475
  133. package/coverage/src/irdevice/fan.ts.html +0 -766
  134. package/coverage/src/irdevice/index.html +0 -251
  135. package/coverage/src/irdevice/irdevice.ts.html +0 -1117
  136. package/coverage/src/irdevice/light.ts.html +0 -826
  137. package/coverage/src/irdevice/other.ts.html +0 -2458
  138. package/coverage/src/irdevice/tv.ts.html +0 -1222
  139. package/coverage/src/irdevice/vacuumcleaner.ts.html +0 -466
  140. package/coverage/src/irdevice/waterheater.ts.html +0 -469
  141. package/coverage/src/platform.ts.html +0 -8776
  142. package/coverage/src/settings.ts.html +0 -934
  143. package/coverage/src/utils.ts.html +0 -2092
  144. package/dist/devices-hap/airpurifier.d.ts +0 -54
  145. package/dist/devices-hap/airpurifier.d.ts.map +0 -1
  146. package/dist/devices-hap/airpurifier.js +0 -533
  147. package/dist/devices-hap/airpurifier.js.map +0 -1
  148. package/dist/devices-hap/blindtilt.d.ts +0 -90
  149. package/dist/devices-hap/blindtilt.d.ts.map +0 -1
  150. package/dist/devices-hap/blindtilt.js +0 -974
  151. package/dist/devices-hap/blindtilt.js.map +0 -1
  152. package/dist/devices-hap/bot.d.ts +0 -102
  153. package/dist/devices-hap/bot.d.ts.map +0 -1
  154. package/dist/devices-hap/bot.js +0 -822
  155. package/dist/devices-hap/bot.js.map +0 -1
  156. package/dist/devices-hap/ceilinglight.d.ts +0 -85
  157. package/dist/devices-hap/ceilinglight.d.ts.map +0 -1
  158. package/dist/devices-hap/ceilinglight.js +0 -707
  159. package/dist/devices-hap/ceilinglight.js.map +0 -1
  160. package/dist/devices-hap/colorbulb.d.ts +0 -88
  161. package/dist/devices-hap/colorbulb.d.ts.map +0 -1
  162. package/dist/devices-hap/colorbulb.js +0 -921
  163. package/dist/devices-hap/colorbulb.js.map +0 -1
  164. package/dist/devices-hap/contact.d.ts +0 -44
  165. package/dist/devices-hap/contact.d.ts.map +0 -1
  166. package/dist/devices-hap/contact.js +0 -409
  167. package/dist/devices-hap/contact.js.map +0 -1
  168. package/dist/devices-hap/curtain.d.ts +0 -73
  169. package/dist/devices-hap/curtain.d.ts.map +0 -1
  170. package/dist/devices-hap/curtain.js +0 -869
  171. package/dist/devices-hap/curtain.js.map +0 -1
  172. package/dist/devices-hap/device.d.ts +0 -108
  173. package/dist/devices-hap/device.d.ts.map +0 -1
  174. package/dist/devices-hap/device.js +0 -821
  175. package/dist/devices-hap/device.js.map +0 -1
  176. package/dist/devices-hap/fan.d.ts +0 -69
  177. package/dist/devices-hap/fan.d.ts.map +0 -1
  178. package/dist/devices-hap/fan.js +0 -655
  179. package/dist/devices-hap/fan.js.map +0 -1
  180. package/dist/devices-hap/hub.d.ts +0 -37
  181. package/dist/devices-hap/hub.d.ts.map +0 -1
  182. package/dist/devices-hap/hub.js +0 -393
  183. package/dist/devices-hap/hub.js.map +0 -1
  184. package/dist/devices-hap/humidifier.d.ts +0 -73
  185. package/dist/devices-hap/humidifier.d.ts.map +0 -1
  186. package/dist/devices-hap/humidifier.js +0 -716
  187. package/dist/devices-hap/humidifier.js.map +0 -1
  188. package/dist/devices-hap/iosensor.d.ts +0 -42
  189. package/dist/devices-hap/iosensor.d.ts.map +0 -1
  190. package/dist/devices-hap/iosensor.js +0 -397
  191. package/dist/devices-hap/iosensor.js.map +0 -1
  192. package/dist/devices-hap/lightstrip.d.ts +0 -79
  193. package/dist/devices-hap/lightstrip.d.ts.map +0 -1
  194. package/dist/devices-hap/lightstrip.js +0 -827
  195. package/dist/devices-hap/lightstrip.js.map +0 -1
  196. package/dist/devices-hap/lock.d.ts +0 -53
  197. package/dist/devices-hap/lock.d.ts.map +0 -1
  198. package/dist/devices-hap/lock.js +0 -569
  199. package/dist/devices-hap/lock.js.map +0 -1
  200. package/dist/devices-hap/meter.d.ts +0 -37
  201. package/dist/devices-hap/meter.d.ts.map +0 -1
  202. package/dist/devices-hap/meter.js +0 -380
  203. package/dist/devices-hap/meter.js.map +0 -1
  204. package/dist/devices-hap/meterplus.d.ts +0 -42
  205. package/dist/devices-hap/meterplus.d.ts.map +0 -1
  206. package/dist/devices-hap/meterplus.js +0 -385
  207. package/dist/devices-hap/meterplus.js.map +0 -1
  208. package/dist/devices-hap/meterpro.d.ts +0 -43
  209. package/dist/devices-hap/meterpro.d.ts.map +0 -1
  210. package/dist/devices-hap/meterpro.js +0 -469
  211. package/dist/devices-hap/meterpro.js.map +0 -1
  212. package/dist/devices-hap/motion.d.ts +0 -42
  213. package/dist/devices-hap/motion.d.ts.map +0 -1
  214. package/dist/devices-hap/motion.js +0 -345
  215. package/dist/devices-hap/motion.js.map +0 -1
  216. package/dist/devices-hap/plug.d.ts +0 -49
  217. package/dist/devices-hap/plug.d.ts.map +0 -1
  218. package/dist/devices-hap/plug.js +0 -400
  219. package/dist/devices-hap/plug.js.map +0 -1
  220. package/dist/devices-hap/relayswitch.d.ts +0 -96
  221. package/dist/devices-hap/relayswitch.d.ts.map +0 -1
  222. package/dist/devices-hap/relayswitch.js +0 -642
  223. package/dist/devices-hap/relayswitch.js.map +0 -1
  224. package/dist/devices-hap/robotvacuumcleaner.d.ts +0 -54
  225. package/dist/devices-hap/robotvacuumcleaner.d.ts.map +0 -1
  226. package/dist/devices-hap/robotvacuumcleaner.js +0 -530
  227. package/dist/devices-hap/robotvacuumcleaner.js.map +0 -1
  228. package/dist/devices-hap/waterdetector.d.ts +0 -41
  229. package/dist/devices-hap/waterdetector.d.ts.map +0 -1
  230. package/dist/devices-hap/waterdetector.js +0 -356
  231. package/dist/devices-hap/waterdetector.js.map +0 -1
  232. package/dist/devices-matter/BaseMatterAccessory.d.ts +0 -90
  233. package/dist/devices-matter/BaseMatterAccessory.d.ts.map +0 -1
  234. package/dist/devices-matter/BaseMatterAccessory.js +0 -264
  235. package/dist/devices-matter/BaseMatterAccessory.js.map +0 -1
  236. package/dist/devices-matter/ColorLightAccessory.d.ts +0 -20
  237. package/dist/devices-matter/ColorLightAccessory.d.ts.map +0 -1
  238. package/dist/devices-matter/ColorLightAccessory.js +0 -95
  239. package/dist/devices-matter/ColorLightAccessory.js.map +0 -1
  240. package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts +0 -18
  241. package/dist/devices-matter/ColorTemperatureLightAccessory.d.ts.map +0 -1
  242. package/dist/devices-matter/ColorTemperatureLightAccessory.js +0 -76
  243. package/dist/devices-matter/ColorTemperatureLightAccessory.js.map +0 -1
  244. package/dist/devices-matter/ContactSensorAccessory.d.ts +0 -12
  245. package/dist/devices-matter/ContactSensorAccessory.d.ts.map +0 -1
  246. package/dist/devices-matter/ContactSensorAccessory.js +0 -34
  247. package/dist/devices-matter/ContactSensorAccessory.js.map +0 -1
  248. package/dist/devices-matter/DimmableLightAccessory.d.ts +0 -58
  249. package/dist/devices-matter/DimmableLightAccessory.d.ts.map +0 -1
  250. package/dist/devices-matter/DimmableLightAccessory.js +0 -167
  251. package/dist/devices-matter/DimmableLightAccessory.js.map +0 -1
  252. package/dist/devices-matter/DoorLockAccessory.d.ts +0 -14
  253. package/dist/devices-matter/DoorLockAccessory.d.ts.map +0 -1
  254. package/dist/devices-matter/DoorLockAccessory.js +0 -50
  255. package/dist/devices-matter/DoorLockAccessory.js.map +0 -1
  256. package/dist/devices-matter/ExtendedColorLightAccessory.d.ts +0 -21
  257. package/dist/devices-matter/ExtendedColorLightAccessory.d.ts.map +0 -1
  258. package/dist/devices-matter/ExtendedColorLightAccessory.js +0 -106
  259. package/dist/devices-matter/ExtendedColorLightAccessory.js.map +0 -1
  260. package/dist/devices-matter/FanAccessory.d.ts +0 -16
  261. package/dist/devices-matter/FanAccessory.d.ts.map +0 -1
  262. package/dist/devices-matter/FanAccessory.js +0 -81
  263. package/dist/devices-matter/FanAccessory.js.map +0 -1
  264. package/dist/devices-matter/HumiditySensorAccessory.d.ts +0 -12
  265. package/dist/devices-matter/HumiditySensorAccessory.d.ts.map +0 -1
  266. package/dist/devices-matter/HumiditySensorAccessory.js +0 -34
  267. package/dist/devices-matter/HumiditySensorAccessory.js.map +0 -1
  268. package/dist/devices-matter/LeakSensorAccessory.d.ts +0 -12
  269. package/dist/devices-matter/LeakSensorAccessory.d.ts.map +0 -1
  270. package/dist/devices-matter/LeakSensorAccessory.js +0 -33
  271. package/dist/devices-matter/LeakSensorAccessory.js.map +0 -1
  272. package/dist/devices-matter/LightSensorAccessory.d.ts +0 -12
  273. package/dist/devices-matter/LightSensorAccessory.d.ts.map +0 -1
  274. package/dist/devices-matter/LightSensorAccessory.js +0 -34
  275. package/dist/devices-matter/LightSensorAccessory.js.map +0 -1
  276. package/dist/devices-matter/OccupancySensorAccessory.d.ts +0 -12
  277. package/dist/devices-matter/OccupancySensorAccessory.d.ts.map +0 -1
  278. package/dist/devices-matter/OccupancySensorAccessory.js +0 -39
  279. package/dist/devices-matter/OccupancySensorAccessory.js.map +0 -1
  280. package/dist/devices-matter/OnOffLightAccessory.d.ts +0 -38
  281. package/dist/devices-matter/OnOffLightAccessory.d.ts.map +0 -1
  282. package/dist/devices-matter/OnOffLightAccessory.js +0 -110
  283. package/dist/devices-matter/OnOffLightAccessory.js.map +0 -1
  284. package/dist/devices-matter/OnOffOutletAccessory.d.ts +0 -14
  285. package/dist/devices-matter/OnOffOutletAccessory.d.ts.map +0 -1
  286. package/dist/devices-matter/OnOffOutletAccessory.js +0 -43
  287. package/dist/devices-matter/OnOffOutletAccessory.js.map +0 -1
  288. package/dist/devices-matter/OnOffSwitchAccessory.d.ts +0 -14
  289. package/dist/devices-matter/OnOffSwitchAccessory.d.ts.map +0 -1
  290. package/dist/devices-matter/OnOffSwitchAccessory.js +0 -42
  291. package/dist/devices-matter/OnOffSwitchAccessory.js.map +0 -1
  292. package/dist/devices-matter/RoboticVacuumAccessory.d.ts +0 -61
  293. package/dist/devices-matter/RoboticVacuumAccessory.d.ts.map +0 -1
  294. package/dist/devices-matter/RoboticVacuumAccessory.js +0 -544
  295. package/dist/devices-matter/RoboticVacuumAccessory.js.map +0 -1
  296. package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts +0 -11
  297. package/dist/devices-matter/SmokeCOAlarmAccessory.d.ts.map +0 -1
  298. package/dist/devices-matter/SmokeCOAlarmAccessory.js +0 -49
  299. package/dist/devices-matter/SmokeCOAlarmAccessory.js.map +0 -1
  300. package/dist/devices-matter/TemperatureSensorAccessory.d.ts +0 -12
  301. package/dist/devices-matter/TemperatureSensorAccessory.d.ts.map +0 -1
  302. package/dist/devices-matter/TemperatureSensorAccessory.js +0 -36
  303. package/dist/devices-matter/TemperatureSensorAccessory.js.map +0 -1
  304. package/dist/devices-matter/ThermostatAccessory.d.ts +0 -19
  305. package/dist/devices-matter/ThermostatAccessory.d.ts.map +0 -1
  306. package/dist/devices-matter/ThermostatAccessory.js +0 -95
  307. package/dist/devices-matter/ThermostatAccessory.js.map +0 -1
  308. package/dist/devices-matter/VenetianBlindAccessory.d.ts +0 -19
  309. package/dist/devices-matter/VenetianBlindAccessory.d.ts.map +0 -1
  310. package/dist/devices-matter/VenetianBlindAccessory.js +0 -99
  311. package/dist/devices-matter/VenetianBlindAccessory.js.map +0 -1
  312. package/dist/devices-matter/WindowBlindAccessory.d.ts +0 -17
  313. package/dist/devices-matter/WindowBlindAccessory.d.ts.map +0 -1
  314. package/dist/devices-matter/WindowBlindAccessory.js +0 -131
  315. package/dist/devices-matter/WindowBlindAccessory.js.map +0 -1
  316. package/dist/devices-matter/custom/PowerStripAccessory.d.ts +0 -97
  317. package/dist/devices-matter/custom/PowerStripAccessory.d.ts.map +0 -1
  318. package/dist/devices-matter/custom/PowerStripAccessory.js +0 -265
  319. package/dist/devices-matter/custom/PowerStripAccessory.js.map +0 -1
  320. package/dist/devices-matter/custom/index.d.ts +0 -8
  321. package/dist/devices-matter/custom/index.d.ts.map +0 -1
  322. package/dist/devices-matter/custom/index.js +0 -8
  323. package/dist/devices-matter/custom/index.js.map +0 -1
  324. package/dist/devices-matter/index.d.ts +0 -29
  325. package/dist/devices-matter/index.d.ts.map +0 -1
  326. package/dist/devices-matter/index.js +0 -28
  327. package/dist/devices-matter/index.js.map +0 -1
  328. package/dist/irdevice/airconditioner.d.ts +0 -61
  329. package/dist/irdevice/airconditioner.d.ts.map +0 -1
  330. package/dist/irdevice/airconditioner.js +0 -472
  331. package/dist/irdevice/airconditioner.js.map +0 -1
  332. package/dist/irdevice/airpurifier.d.ts +0 -50
  333. package/dist/irdevice/airpurifier.d.ts.map +0 -1
  334. package/dist/irdevice/airpurifier.js +0 -213
  335. package/dist/irdevice/airpurifier.js.map +0 -1
  336. package/dist/irdevice/camera.d.ts +0 -32
  337. package/dist/irdevice/camera.d.ts.map +0 -1
  338. package/dist/irdevice/camera.js +0 -107
  339. package/dist/irdevice/camera.js.map +0 -1
  340. package/dist/irdevice/fan.d.ts +0 -36
  341. package/dist/irdevice/fan.d.ts.map +0 -1
  342. package/dist/irdevice/fan.js +0 -200
  343. package/dist/irdevice/fan.js.map +0 -1
  344. package/dist/irdevice/irdevice.d.ts +0 -69
  345. package/dist/irdevice/irdevice.d.ts.map +0 -1
  346. package/dist/irdevice/irdevice.js +0 -339
  347. package/dist/irdevice/irdevice.js.map +0 -1
  348. package/dist/irdevice/light.d.ts +0 -36
  349. package/dist/irdevice/light.d.ts.map +0 -1
  350. package/dist/irdevice/light.js +0 -206
  351. package/dist/irdevice/light.js.map +0 -1
  352. package/dist/irdevice/other.d.ts +0 -57
  353. package/dist/irdevice/other.d.ts.map +0 -1
  354. package/dist/irdevice/other.js +0 -778
  355. package/dist/irdevice/other.js.map +0 -1
  356. package/dist/irdevice/tv.d.ts +0 -45
  357. package/dist/irdevice/tv.d.ts.map +0 -1
  358. package/dist/irdevice/tv.js +0 -327
  359. package/dist/irdevice/tv.js.map +0 -1
  360. package/dist/irdevice/vacuumcleaner.d.ts +0 -28
  361. package/dist/irdevice/vacuumcleaner.d.ts.map +0 -1
  362. package/dist/irdevice/vacuumcleaner.js +0 -104
  363. package/dist/irdevice/vacuumcleaner.js.map +0 -1
  364. package/dist/irdevice/waterheater.d.ts +0 -30
  365. package/dist/irdevice/waterheater.d.ts.map +0 -1
  366. package/dist/irdevice/waterheater.js +0 -105
  367. package/dist/irdevice/waterheater.js.map +0 -1
  368. package/dist/platform-hap.d.ts +0 -160
  369. package/dist/platform-hap.d.ts.map +0 -1
  370. package/dist/platform-hap.js +0 -3041
  371. package/dist/platform-hap.js.map +0 -1
  372. package/dist/platform-matter.d.ts +0 -188
  373. package/dist/platform-matter.d.ts.map +0 -1
  374. package/dist/platform-matter.js +0 -2545
  375. package/dist/platform-matter.js.map +0 -1
  376. package/dist/test/apiRequestTracker.test.d.ts +0 -2
  377. package/dist/test/apiRequestTracker.test.d.ts.map +0 -1
  378. package/dist/test/apiRequestTracker.test.js +0 -392
  379. package/dist/test/apiRequestTracker.test.js.map +0 -1
  380. package/dist/test/hap/device-webhook-context.test.d.ts +0 -2
  381. package/dist/test/hap/device-webhook-context.test.d.ts.map +0 -1
  382. package/dist/test/hap/device-webhook-context.test.js +0 -128
  383. package/dist/test/hap/device-webhook-context.test.js.map +0 -1
  384. package/dist/test/hap/platform-hap.logging.test.d.ts +0 -2
  385. package/dist/test/hap/platform-hap.logging.test.d.ts.map +0 -1
  386. package/dist/test/hap/platform-hap.logging.test.js +0 -33
  387. package/dist/test/hap/platform-hap.logging.test.js.map +0 -1
  388. package/dist/test/hap/platform-hap.test.d.ts +0 -2
  389. package/dist/test/hap/platform-hap.test.d.ts.map +0 -1
  390. package/dist/test/hap/platform-hap.test.js +0 -62
  391. package/dist/test/hap/platform-hap.test.js.map +0 -1
  392. package/dist/test/helpers/platform-fixtures.d.ts +0 -9
  393. package/dist/test/helpers/platform-fixtures.d.ts.map +0 -1
  394. package/dist/test/helpers/platform-fixtures.js +0 -30
  395. package/dist/test/helpers/platform-fixtures.js.map +0 -1
  396. package/dist/test/homebridge-ui/server.test.d.ts +0 -2
  397. package/dist/test/homebridge-ui/server.test.d.ts.map +0 -1
  398. package/dist/test/homebridge-ui/server.test.js +0 -445
  399. package/dist/test/homebridge-ui/server.test.js.map +0 -1
  400. package/dist/test/index.test.d.ts +0 -2
  401. package/dist/test/index.test.d.ts.map +0 -1
  402. package/dist/test/index.test.js +0 -19
  403. package/dist/test/index.test.js.map +0 -1
  404. package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts +0 -2
  405. package/dist/test/matter/devices-matter/baseMatterAccessory.test.d.ts.map +0 -1
  406. package/dist/test/matter/devices-matter/baseMatterAccessory.test.js +0 -71
  407. package/dist/test/matter/devices-matter/baseMatterAccessory.test.js.map +0 -1
  408. package/dist/test/matter/platform-matter.additional.test.d.ts +0 -2
  409. package/dist/test/matter/platform-matter.additional.test.d.ts.map +0 -1
  410. package/dist/test/matter/platform-matter.additional.test.js +0 -35
  411. package/dist/test/matter/platform-matter.additional.test.js.map +0 -1
  412. package/dist/test/matter/platform-matter.bleparse.test.d.ts +0 -2
  413. package/dist/test/matter/platform-matter.bleparse.test.d.ts.map +0 -1
  414. package/dist/test/matter/platform-matter.bleparse.test.js +0 -43
  415. package/dist/test/matter/platform-matter.bleparse.test.js.map +0 -1
  416. package/dist/test/matter/platform-matter.cleanup.test.d.ts +0 -2
  417. package/dist/test/matter/platform-matter.cleanup.test.d.ts.map +0 -1
  418. package/dist/test/matter/platform-matter.cleanup.test.js +0 -70
  419. package/dist/test/matter/platform-matter.cleanup.test.js.map +0 -1
  420. package/dist/test/matter/platform-matter.keepstale.test.d.ts +0 -2
  421. package/dist/test/matter/platform-matter.keepstale.test.d.ts.map +0 -1
  422. package/dist/test/matter/platform-matter.keepstale.test.js +0 -27
  423. package/dist/test/matter/platform-matter.keepstale.test.js.map +0 -1
  424. package/dist/test/matter/platform-matter.logging.test.d.ts +0 -2
  425. package/dist/test/matter/platform-matter.logging.test.d.ts.map +0 -1
  426. package/dist/test/matter/platform-matter.logging.test.js +0 -29
  427. package/dist/test/matter/platform-matter.logging.test.js.map +0 -1
  428. package/dist/test/matter/platform-matter.mapping.test.d.ts +0 -2
  429. package/dist/test/matter/platform-matter.mapping.test.d.ts.map +0 -1
  430. package/dist/test/matter/platform-matter.mapping.test.js +0 -43
  431. package/dist/test/matter/platform-matter.mapping.test.js.map +0 -1
  432. package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts +0 -2
  433. package/dist/test/matter/platform-matter.openapi-mapping.test.d.ts.map +0 -1
  434. package/dist/test/matter/platform-matter.openapi-mapping.test.js +0 -84
  435. package/dist/test/matter/platform-matter.openapi-mapping.test.js.map +0 -1
  436. package/dist/test/matter/platform-matter.test.d.ts +0 -2
  437. package/dist/test/matter/platform-matter.test.d.ts.map +0 -1
  438. package/dist/test/matter/platform-matter.test.js +0 -117
  439. package/dist/test/matter/platform-matter.test.js.map +0 -1
  440. package/dist/test/matter/platform-matter.unregister.test.d.ts +0 -2
  441. package/dist/test/matter/platform-matter.unregister.test.d.ts.map +0 -1
  442. package/dist/test/matter/platform-matter.unregister.test.js +0 -30
  443. package/dist/test/matter/platform-matter.unregister.test.js.map +0 -1
  444. package/dist/test/matter/platform-matter.webhook.test.d.ts +0 -2
  445. package/dist/test/matter/platform-matter.webhook.test.d.ts.map +0 -1
  446. package/dist/test/matter/platform-matter.webhook.test.js +0 -46
  447. package/dist/test/matter/platform-matter.webhook.test.js.map +0 -1
  448. package/dist/test/utils.test.d.ts +0 -2
  449. package/dist/test/utils.test.d.ts.map +0 -1
  450. package/dist/test/utils.test.js +0 -95
  451. package/dist/test/utils.test.js.map +0 -1
  452. package/dist/test/verifyconfig.test.d.ts +0 -2
  453. package/dist/test/verifyconfig.test.d.ts.map +0 -1
  454. package/dist/test/verifyconfig.test.js +0 -167
  455. package/dist/test/verifyconfig.test.js.map +0 -1
  456. package/src/custom.d.ts +0 -7
  457. package/src/devices-hap/airpurifier.ts +0 -568
  458. package/src/devices-hap/blindtilt.ts +0 -1049
  459. package/src/devices-hap/bot.ts +0 -910
  460. package/src/devices-hap/ceilinglight.ts +0 -747
  461. package/src/devices-hap/colorbulb.ts +0 -940
  462. package/src/devices-hap/contact.ts +0 -457
  463. package/src/devices-hap/curtain.ts +0 -944
  464. package/src/devices-hap/device.ts +0 -890
  465. package/src/devices-hap/fan.ts +0 -716
  466. package/src/devices-hap/hub.ts +0 -440
  467. package/src/devices-hap/humidifier.ts +0 -762
  468. package/src/devices-hap/iosensor.ts +0 -442
  469. package/src/devices-hap/lightstrip.ts +0 -863
  470. package/src/devices-hap/lock.ts +0 -627
  471. package/src/devices-hap/meter.ts +0 -427
  472. package/src/devices-hap/meterplus.ts +0 -431
  473. package/src/devices-hap/meterpro.ts +0 -523
  474. package/src/devices-hap/motion.ts +0 -390
  475. package/src/devices-hap/plug.ts +0 -427
  476. package/src/devices-hap/relayswitch.ts +0 -727
  477. package/src/devices-hap/robotvacuumcleaner.ts +0 -574
  478. package/src/devices-hap/waterdetector.ts +0 -400
  479. package/src/devices-matter/BaseMatterAccessory.ts +0 -302
  480. package/src/devices-matter/ColorLightAccessory.ts +0 -110
  481. package/src/devices-matter/ColorTemperatureLightAccessory.ts +0 -90
  482. package/src/devices-matter/ContactSensorAccessory.ts +0 -41
  483. package/src/devices-matter/DimmableLightAccessory.ts +0 -192
  484. package/src/devices-matter/DoorLockAccessory.ts +0 -60
  485. package/src/devices-matter/ExtendedColorLightAccessory.ts +0 -122
  486. package/src/devices-matter/FanAccessory.ts +0 -95
  487. package/src/devices-matter/HumiditySensorAccessory.ts +0 -41
  488. package/src/devices-matter/LeakSensorAccessory.ts +0 -40
  489. package/src/devices-matter/LightSensorAccessory.ts +0 -41
  490. package/src/devices-matter/OccupancySensorAccessory.ts +0 -48
  491. package/src/devices-matter/OnOffLightAccessory.ts +0 -125
  492. package/src/devices-matter/OnOffOutletAccessory.ts +0 -51
  493. package/src/devices-matter/OnOffSwitchAccessory.ts +0 -51
  494. package/src/devices-matter/RoboticVacuumAccessory.ts +0 -621
  495. package/src/devices-matter/SmokeCOAlarmAccessory.ts +0 -59
  496. package/src/devices-matter/TemperatureSensorAccessory.ts +0 -43
  497. package/src/devices-matter/ThermostatAccessory.ts +0 -110
  498. package/src/devices-matter/VenetianBlindAccessory.ts +0 -115
  499. package/src/devices-matter/WindowBlindAccessory.ts +0 -135
  500. package/src/devices-matter/custom/PowerStripAccessory.ts +0 -309
  501. package/src/devices-matter/custom/index.ts +0 -8
  502. package/src/devices-matter/index.ts +0 -29
  503. package/src/irdevice/airconditioner.ts +0 -533
  504. package/src/irdevice/airpurifier.ts +0 -252
  505. package/src/irdevice/camera.ts +0 -129
  506. package/src/irdevice/fan.ts +0 -226
  507. package/src/irdevice/irdevice.ts +0 -383
  508. package/src/irdevice/light.ts +0 -246
  509. package/src/irdevice/other.ts +0 -790
  510. package/src/irdevice/tv.ts +0 -378
  511. package/src/irdevice/vacuumcleaner.ts +0 -126
  512. package/src/irdevice/waterheater.ts +0 -127
  513. package/src/platform-hap.ts +0 -3193
  514. package/src/platform-matter.ts +0 -2703
  515. package/src/test/apiRequestTracker.test.ts +0 -417
  516. package/src/test/hap/device-webhook-context.test.ts +0 -136
  517. package/src/test/hap/platform-hap.logging.test.ts +0 -36
  518. package/src/test/hap/platform-hap.test.ts +0 -70
  519. package/src/test/helpers/platform-fixtures.ts +0 -33
  520. package/src/test/homebridge-ui/server.test.ts +0 -486
  521. package/src/test/index.test.ts +0 -24
  522. package/src/test/matter/devices-matter/baseMatterAccessory.test.ts +0 -88
  523. package/src/test/matter/platform-matter.additional.test.ts +0 -44
  524. package/src/test/matter/platform-matter.bleparse.test.ts +0 -47
  525. package/src/test/matter/platform-matter.cleanup.test.ts +0 -86
  526. package/src/test/matter/platform-matter.keepstale.test.ts +0 -37
  527. package/src/test/matter/platform-matter.logging.test.ts +0 -33
  528. package/src/test/matter/platform-matter.mapping.test.ts +0 -57
  529. package/src/test/matter/platform-matter.openapi-mapping.test.ts +0 -109
  530. package/src/test/matter/platform-matter.test.ts +0 -144
  531. package/src/test/matter/platform-matter.unregister.test.ts +0 -39
  532. package/src/test/matter/platform-matter.webhook.test.ts +0 -54
  533. package/src/test/utils.test.ts +0 -96
  534. package/src/test/verifyconfig.test.ts +0 -198
@@ -1,627 +0,0 @@
1
- /* Copyright(C) 2021-2024, donavanbecker (https://github.com/donavanbecker). All rights reserved.
2
- *
3
- * lock.ts: @switchbot/homebridge-switchbot.
4
- */
5
- import type { CharacteristicValue, PlatformAccessory, Service } from 'homebridge'
6
- import type { bodyChange, device, lockProServiceData, lockProStatus, lockProWebhookContext, lockServiceData, lockStatus, lockWebhookContext, SwitchBotBLE, SwitchbotDevice, WoSmartLock } from 'node-switchbot'
7
-
8
- import type { SwitchBotHAPPlatform } from '../platform-hap.js'
9
- import type { devicesConfig, lockConfig } from '../settings.js'
10
-
11
- /*
12
- * For Testing Locally:
13
- * import { SwitchBotBLEModel, SwitchBotBLEModelName } from '/Users/Shared/GitHub/OpenWonderLabs/node-switchbot/dist/index.js';
14
- */
15
- import { SwitchBotBLEModel, SwitchBotBLEModelName } from 'node-switchbot'
16
- import { debounceTime, interval, skipWhile, Subject, take, tap } from 'rxjs'
17
-
18
- import { formatDeviceIdAsMac } from '../utils.js'
19
- import { deviceBase } from './device.js'
20
-
21
- export class Lock extends deviceBase {
22
- // Services
23
- private LockMechanism: {
24
- Name: CharacteristicValue
25
- Service: Service
26
- LockTargetState: CharacteristicValue
27
- LockCurrentState: CharacteristicValue
28
- }
29
-
30
- private Battery: {
31
- Name: CharacteristicValue
32
- Service: Service
33
- BatteryLevel: CharacteristicValue
34
- StatusLowBattery: CharacteristicValue
35
- }
36
-
37
- private ContactSensor?: {
38
- Name: CharacteristicValue
39
- Service: Service
40
- ContactSensorState: CharacteristicValue
41
- }
42
-
43
- private Switch?: {
44
- Name: CharacteristicValue
45
- Service: Service
46
- On: CharacteristicValue
47
- }
48
-
49
- // OpenAPI
50
- deviceStatus!: lockStatus | lockProStatus
51
-
52
- // Webhook
53
- webhookContext!: lockWebhookContext | lockProWebhookContext
54
-
55
- // BLE
56
- serviceData!: lockServiceData | lockProServiceData
57
-
58
- // Updates
59
- lockUpdateInProgress!: boolean
60
- doLockUpdate!: Subject<void>
61
-
62
- constructor(
63
- readonly platform: SwitchBotHAPPlatform,
64
- accessory: PlatformAccessory,
65
- device: device & devicesConfig,
66
- ) {
67
- super(platform, accessory, device)
68
- // Set category
69
- accessory.category = this.hap.Categories.DOOR_LOCK
70
-
71
- // this is subject we use to track when we need to POST changes to the SwitchBot API
72
- this.doLockUpdate = new Subject()
73
- this.lockUpdateInProgress = false
74
-
75
- // Initialize LockMechanism Service
76
- accessory.context.LockMechanism = accessory.context.LockMechanism ?? {}
77
- this.LockMechanism = {
78
- Name: accessory.displayName,
79
- Service: accessory.getService(this.hap.Service.LockMechanism) ?? accessory.addService(this.hap.Service.LockMechanism) as Service,
80
- LockTargetState: accessory.context.LockTargetState ?? this.hap.Characteristic.LockTargetState.SECURED,
81
- LockCurrentState: accessory.context.LockCurrentState ?? this.hap.Characteristic.LockCurrentState.SECURED,
82
- }
83
- accessory.context.LockMechanism = this.LockMechanism as object
84
-
85
- // Initialize LockMechanism Characteristics
86
- this.LockMechanism.Service.setCharacteristic(this.hap.Characteristic.Name, this.LockMechanism.Name).getCharacteristic(this.hap.Characteristic.LockTargetState).onGet(() => {
87
- return this.LockMechanism.LockTargetState
88
- }).onSet(this.LockTargetStateSet.bind(this))
89
-
90
- // Initialize Battery property
91
- accessory.context.Battery = accessory.context.Battery ?? {}
92
- this.Battery = {
93
- Name: `${accessory.displayName} Battery`,
94
- Service: accessory.getService(this.hap.Service.Battery) ?? accessory.addService(this.hap.Service.Battery) as Service,
95
- BatteryLevel: accessory.context.BatteryLevel ?? 100,
96
- StatusLowBattery: accessory.context.StatusLowBattery ?? this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_NORMAL,
97
- }
98
- accessory.context.Battery = this.Battery as object
99
-
100
- // Initialize Battery Characteristics
101
- this.Battery.Service.setCharacteristic(this.hap.Characteristic.Name, this.Battery.Name).setCharacteristic(this.hap.Characteristic.ChargingState, this.hap.Characteristic.ChargingState.NOT_CHARGEABLE).getCharacteristic(this.hap.Characteristic.BatteryLevel).onGet(() => {
102
- return this.Battery.BatteryLevel
103
- })
104
-
105
- this.Battery.Service.getCharacteristic(this.hap.Characteristic.StatusLowBattery).onGet(() => {
106
- return this.Battery.StatusLowBattery
107
- })
108
-
109
- // Contact Sensor Service
110
- if ((device as lockConfig).hide_contactsensor) {
111
- if (this.ContactSensor) {
112
- this.debugLog('Removing Contact Sensor Service')
113
- this.ContactSensor.Service = this.accessory.getService(this.hap.Service.ContactSensor) as Service
114
- accessory.removeService(this.ContactSensor.Service)
115
- }
116
- } else {
117
- accessory.context.ContactSensor = accessory.context.ContactSensor ?? {}
118
- this.ContactSensor = {
119
- Name: `${accessory.displayName} Contact Sensor`,
120
- Service: accessory.getService(this.hap.Service.ContactSensor) ?? this.accessory.addService(this.hap.Service.ContactSensor) as Service,
121
- ContactSensorState: accessory.context.ContactSensorState ?? this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED,
122
- }
123
- accessory.context.ContactSensor = this.ContactSensor as object
124
-
125
- // Initialize Contact Sensor Characteristics
126
- this.ContactSensor.Service.setCharacteristic(this.hap.Characteristic.Name, this.ContactSensor.Name).setCharacteristic(this.hap.Characteristic.StatusActive, true).getCharacteristic(this.hap.Characteristic.ContactSensorState).onGet(() => {
127
- return this.ContactSensor!.ContactSensorState
128
- })
129
- }
130
-
131
- // Initialize Latch Button Service
132
- if ((device as lockConfig).activate_latchbutton === false) {
133
- if (this.Switch) {
134
- this.debugLog('Removing Latch Button Service')
135
- this.Switch.Service = accessory.getService(this.hap.Service.Switch) as Service
136
- accessory.removeService(this.Switch.Service)
137
- }
138
- } else {
139
- accessory.context.Switch = accessory.context.Switch ?? {}
140
- this.Switch = {
141
- Name: `${accessory.displayName} Latch`,
142
- Service: accessory.getService(this.hap.Service.Switch) ?? accessory.addService(this.hap.Service.Switch) as Service,
143
- On: accessory.context.On ?? false,
144
- }
145
- accessory.context.Switch = this.Switch as object
146
-
147
- // Initialize Latch Button Characteristics
148
- this.Switch.Service.setCharacteristic(this.hap.Characteristic.Name, this.Switch.Name).getCharacteristic(this.hap.Characteristic.On).onGet(() => {
149
- return this.Switch!.On
150
- }).onSet(this.OnSet.bind(this))
151
- }
152
-
153
- // Retrieve initial values and updateHomekit
154
- try {
155
- this.debugLog('Retrieve initial values and update Homekit')
156
- this.refreshStatus()
157
- } catch (e: any) {
158
- this.errorLog(`failed to retrieve initial values and update Homekit, Error: ${e.message ?? e}`)
159
- }
160
-
161
- // regisiter webhook event handler if enabled
162
- try {
163
- this.debugLog('Registering Webhook Event Handler')
164
- this.registerWebhook()
165
- } catch (e: any) {
166
- this.errorLog(`failed to registerWebhook, Error: ${e.message ?? e}`)
167
- }
168
-
169
- // regisiter platform BLE event handler if enabled
170
- try {
171
- this.debugLog('Registering Platform BLE Event Handler')
172
- this.registerPlatformBLE()
173
- } catch (e: any) {
174
- this.errorLog(`failed to registerPlatformBLE, Error: ${e.message ?? e}`)
175
- }
176
-
177
- // Start an update interval
178
- interval(this.deviceRefreshRate * 1000)
179
- .pipe(skipWhile(() => this.lockUpdateInProgress))
180
- .subscribe(async () => {
181
- await this.refreshStatus()
182
- })
183
-
184
- // Watch for Lock change events
185
- // We put in a debounce of 100ms so we don't make duplicate calls
186
- this.doLockUpdate
187
- .pipe(
188
- tap(() => {
189
- this.lockUpdateInProgress = true
190
- }),
191
- debounceTime(this.devicePushRate * 1000),
192
- )
193
- .subscribe(async () => {
194
- try {
195
- await this.pushChanges()
196
- } catch (e: any) {
197
- await this.apiError(e)
198
- this.errorLog(`failed pushChanges with ${device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)
199
- }
200
- this.lockUpdateInProgress = false
201
- })
202
- }
203
-
204
- async BLEparseStatus(): Promise<void> {
205
- this.debugLog('BLEparseStatus')
206
- this.debugLog(`(lockState) = BLE:(${this.serviceData.status}), current:(${this.LockMechanism.LockCurrentState})`)
207
-
208
- // LockCurrentState
209
- this.LockMechanism.LockCurrentState = this.serviceData.status === 'locked'
210
- ? this.hap.Characteristic.LockCurrentState.SECURED
211
- : this.hap.Characteristic.LockCurrentState.UNSECURED
212
- this.debugLog(`LockCurrentState: ${this.LockMechanism.LockCurrentState}`)
213
-
214
- // LockTargetState
215
- this.LockMechanism.LockTargetState = this.serviceData.status === 'locked'
216
- ? this.hap.Characteristic.LockTargetState.SECURED
217
- : this.hap.Characteristic.LockTargetState.UNSECURED
218
- this.debugLog(`LockTargetState: ${this.LockMechanism.LockTargetState}`)
219
-
220
- // Contact Sensor
221
- if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {
222
- this.ContactSensor.ContactSensorState = this.serviceData.door_open
223
- ? this.hap.Characteristic.ContactSensorState.CONTACT_NOT_DETECTED
224
- : this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED
225
- this.debugLog(`ContactSensorState: ${this.ContactSensor.ContactSensorState}`)
226
- }
227
- // Battery Info
228
- if ('battery' in this.serviceData) {
229
- // BatteryLevel
230
- this.Battery.BatteryLevel = this.serviceData.battery
231
- this.debugLog(`BatteryLevel: ${this.Battery.BatteryLevel}`)
232
- // StatusLowBattery
233
- this.Battery.StatusLowBattery = this.Battery.BatteryLevel < 10
234
- ? this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_LOW
235
- : this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_NORMAL
236
- this.debugLog(`StatusLowBattery: ${this.Battery.StatusLowBattery}`)
237
- }
238
- }
239
-
240
- async openAPIparseStatus(): Promise<void> {
241
- this.debugLog('openAPIparseStatus')
242
- this.debugLog(`(lockState) = OpenAPI:(${this.deviceStatus.lockState}), current:(${this.LockMechanism.LockCurrentState})`)
243
-
244
- // LockCurrentState
245
- this.LockMechanism.LockCurrentState = this.deviceStatus.lockState === 'locked'
246
- ? this.hap.Characteristic.LockCurrentState.SECURED
247
- : this.hap.Characteristic.LockCurrentState.UNSECURED
248
- this.debugLog(`LockCurrentState: ${this.LockMechanism.LockCurrentState}`)
249
-
250
- // LockTargetState
251
- this.LockMechanism.LockTargetState = this.deviceStatus.lockState === 'locked'
252
- ? this.hap.Characteristic.LockTargetState.SECURED
253
- : this.hap.Characteristic.LockTargetState.UNSECURED
254
- this.debugLog(`LockTargetState: ${this.LockMechanism.LockTargetState}`)
255
-
256
- // ContactSensorState
257
- if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {
258
- this.ContactSensor.ContactSensorState = this.deviceStatus.doorState === 'opened'
259
- ? this.hap.Characteristic.ContactSensorState.CONTACT_NOT_DETECTED
260
- : this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED
261
- this.debugLog(`ContactSensorState: ${this.ContactSensor.ContactSensorState}`)
262
- }
263
-
264
- // BatteryLevel
265
- this.Battery.BatteryLevel = this.deviceStatus.battery
266
- this.debugLog(`BatteryLevel: ${this.Battery.BatteryLevel}`)
267
-
268
- // StatusLowBattery
269
- this.Battery.StatusLowBattery = this.Battery.BatteryLevel < 10
270
- ? this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_LOW
271
- : this.hap.Characteristic.StatusLowBattery.BATTERY_LEVEL_NORMAL
272
- this.debugLog(`StatusLowBattery: ${this.Battery.StatusLowBattery}`)
273
-
274
- // Firmware Version
275
- if (this.deviceStatus.version) {
276
- const version = this.deviceStatus.version.toString()
277
- this.debugLog(`Firmware Version: ${version.replace(/^V|-.*$/g, '')}`)
278
- const deviceVersion = version.replace(/^V|-.*$/g, '') ?? '0.0.0'
279
- this.accessory
280
- .getService(this.hap.Service.AccessoryInformation)!
281
- .setCharacteristic(this.hap.Characteristic.HardwareRevision, deviceVersion)
282
- .setCharacteristic(this.hap.Characteristic.FirmwareRevision, deviceVersion)
283
- .getCharacteristic(this.hap.Characteristic.FirmwareRevision)
284
- .updateValue(deviceVersion)
285
- this.accessory.context.version = deviceVersion
286
- this.debugSuccessLog(`version: ${this.accessory.context.version}`)
287
- }
288
- }
289
-
290
- async parseStatusWebhook(): Promise<void> {
291
- this.debugLog('parseStatusWebhook')
292
- this.debugLog(`(lockState) = Webhook:(${this.webhookContext.lockState}), current:(${this.LockMechanism.LockCurrentState})`)
293
-
294
- // LockCurrentState
295
- this.LockMechanism.LockCurrentState = this.webhookContext.lockState === 'LOCKED'
296
- ? this.hap.Characteristic.LockCurrentState.SECURED
297
- : this.hap.Characteristic.LockCurrentState.UNSECURED
298
- this.debugLog(`LockCurrentState: ${this.LockMechanism.LockCurrentState}`)
299
-
300
- // LockTargetState
301
- this.LockMechanism.LockTargetState = this.webhookContext.lockState === 'LOCKED'
302
- ? this.hap.Characteristic.LockTargetState.SECURED
303
- : this.hap.Characteristic.LockTargetState.UNSECURED
304
- this.debugLog(`LockTargetState: ${this.LockMechanism.LockTargetState}`)
305
- }
306
-
307
- /**
308
- * Asks the SwitchBot API for the latest device information
309
- */
310
- async refreshStatus(): Promise<void> {
311
- if (this.BLE) {
312
- await this.BLERefreshStatus()
313
- } else if (this.OpenAPI && this.platform.config.credentials?.token) {
314
- await this.openAPIRefreshStatus()
315
- } else {
316
- await this.offlineOff()
317
- this.debugWarnLog(`Connection Type: ${this.device.connectionType}, refreshStatus will not happen.`)
318
- }
319
- }
320
-
321
- async BLERefreshStatus(): Promise<void> {
322
- this.debugLog('BLERefreshStatus')
323
- const switchBotBLE = await this.switchbotBLE()
324
- if (switchBotBLE === undefined) {
325
- await this.BLERefreshConnection(switchBotBLE)
326
- } else {
327
- // Start to monitor advertisement packets
328
- (async () => {
329
- // Start to monitor advertisement packets
330
- const serviceData = await this.monitorAdvertisementPackets(switchBotBLE) as lockServiceData | lockProServiceData
331
- // Update HomeKit
332
- if ((serviceData.model === SwitchBotBLEModel.Lock || SwitchBotBLEModel.LockPro)
333
- && (serviceData.modelName === SwitchBotBLEModelName.Lock || SwitchBotBLEModelName.LockPro)) {
334
- this.serviceData = serviceData
335
- if (serviceData !== undefined && serviceData !== null) {
336
- await this.BLEparseStatus()
337
- await this.updateHomeKitCharacteristics()
338
- } else {
339
- this.errorLog(`serviceData is either undefined or null, serviceData: ${JSON.stringify(serviceData)}`)
340
- await this.BLERefreshConnection(switchBotBLE)
341
- }
342
- } else {
343
- this.errorLog(`failed to get serviceData, serviceData: ${JSON.stringify(serviceData)}`)
344
- await this.BLERefreshConnection(switchBotBLE)
345
- }
346
- })()
347
- }
348
- }
349
-
350
- async registerPlatformBLE(): Promise<void> {
351
- this.debugLog('registerPlatformBLE')
352
- if (this.config.options?.BLE && !this.device.disablePlatformBLE) {
353
- this.debugLog('is listening to Platform BLE.')
354
- try {
355
- const formattedDeviceId = formatDeviceIdAsMac(this.device.deviceId)
356
- this.device.bleMac = formattedDeviceId
357
- this.debugLog(`bleMac: ${this.device.bleMac}`)
358
- this.platform.bleEventHandler[this.device.bleMac] = async (context: lockServiceData | lockProServiceData) => {
359
- try {
360
- this.serviceData = context
361
- if (context !== undefined && context !== null) {
362
- this.debugLog(`received BLE: ${JSON.stringify(context)}`)
363
- await this.BLEparseStatus()
364
- await this.updateHomeKitCharacteristics()
365
- } else {
366
- this.errorLog(`context is either undefined or null, context: ${JSON.stringify(context)}`)
367
- await this.BLERefreshConnection(context)
368
- }
369
- } catch (e: any) {
370
- this.errorLog(`failed to handle BLE. Received: ${JSON.stringify(context)} Error: ${e.message ?? e}`)
371
- }
372
- }
373
- } catch (error) {
374
- this.errorLog(`failed to format device ID as MAC, Error: ${error}`)
375
- }
376
- } else {
377
- this.debugLog('is not listening to Platform BLE')
378
- }
379
- }
380
-
381
- async openAPIRefreshStatus(): Promise<void> {
382
- this.debugLog('openAPIRefreshStatus')
383
- try {
384
- const deviceStatus = await this.deviceRefreshStatus<lockStatus | lockProStatus>()
385
- this.debugLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)
386
- if (await this.successfulStatusCodes(deviceStatus)) {
387
- this.debugSuccessLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)
388
- this.deviceStatus = deviceStatus.body
389
- await this.openAPIparseStatus()
390
- await this.updateHomeKitCharacteristics()
391
- } else {
392
- this.debugWarnLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)
393
- }
394
- } catch (e: any) {
395
- await this.apiError(e)
396
- this.errorLog(`failed openAPIRefreshStatus with ${this.device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)
397
- }
398
- }
399
-
400
- async registerWebhook() {
401
- if (this.device.webhook) {
402
- this.debugLog('is listening webhook.')
403
- this.platform.webhookEventHandler[this.device.deviceId] = async (context: lockWebhookContext | lockProWebhookContext) => {
404
- try {
405
- this.webhookContext = context
406
- if (context !== undefined && context !== null) {
407
- this.debugLog(`received Webhook: ${JSON.stringify(context)}`)
408
- await this.parseStatusWebhook()
409
- await this.updateHomeKitCharacteristics()
410
- } else {
411
- this.errorLog(`context is either undefined or null, context: ${JSON.stringify(context)}`)
412
- }
413
- } catch (e: any) {
414
- this.errorLog(`failed to handle webhook. Received: ${JSON.stringify(context)} Error: ${e.message ?? e}`)
415
- }
416
- }
417
- } else {
418
- this.debugLog('is not listening webhook.')
419
- }
420
- }
421
-
422
- /**
423
- * Pushes the requested changes to the SwitchBot API
424
- * deviceType commandType Command command parameter Description
425
- * Lock - "command" "lock" "default" = set to ???? state
426
- * Lock - "command" "unlock" "default" = set to ???? state - LockCurrentState
427
- */
428
- async pushChanges(): Promise<void> {
429
- if (this.BLE) {
430
- await this.BLEpushChanges()
431
- } else if (this.OpenAPI && this.platform.config.credentials?.token) {
432
- await this.openAPIpushChanges()
433
- } else {
434
- await this.offlineOff()
435
- this.debugWarnLog(`Connection Type: ${this.device.connectionType}, pushChanges will not happen.`)
436
- }
437
- // Refresh the status from the API
438
- interval(15000)
439
- .pipe(skipWhile(() => this.lockUpdateInProgress))
440
- .pipe(take(1))
441
- .subscribe(async () => {
442
- await this.refreshStatus()
443
- })
444
- }
445
-
446
- async BLEpushChanges(): Promise<void> {
447
- this.debugLog('BLEpushChanges')
448
- if (this.LockMechanism.LockTargetState !== this.accessory.context.LockTargetState) {
449
- const switchBotBLE = await this.platform.connectBLE(this.accessory, this.device)
450
- try {
451
- const formattedDeviceId = formatDeviceIdAsMac(this.device.deviceId)
452
- this.device.bleMac = formattedDeviceId
453
- this.debugLog(`bleMac: ${this.device.bleMac}`)
454
- if (switchBotBLE !== false) {
455
- switchBotBLE
456
- .discover({ model: this.device.bleModel, id: this.device.bleMac })
457
- .then(async (device_list: SwitchbotDevice[]) => {
458
- const deviceList = device_list as WoSmartLock[]
459
- this.infoLog(`LockTargetState: ${this.LockMechanism.LockTargetState}`)
460
- this.warnLog(`device_list: ${JSON.stringify(device_list)}`)
461
- return await this.retryBLE({
462
- max: this.maxRetryBLE(),
463
- fn: async () => {
464
- if (deviceList && Array.isArray(deviceList) && deviceList.length > 0) {
465
- if (this.LockMechanism.LockTargetState === this.hap.Characteristic.LockTargetState.SECURED) {
466
- return await deviceList[0].lock()
467
- } else {
468
- return await deviceList[0].unlock()
469
- }
470
- } else {
471
- throw new Error('No devices found during discovery.')
472
- }
473
- },
474
- })
475
- })
476
- .then(async () => {
477
- this.successLog(`LockTargetState: ${this.LockMechanism.LockTargetState} sent over SwitchBot BLE, sent successfully`)
478
- await this.updateHomeKitCharacteristics()
479
- })
480
- .catch(async (e: any) => {
481
- await this.apiError(e)
482
- this.errorLog(`failed BLEpushChanges with ${this.device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)
483
- await this.BLEPushConnection()
484
- })
485
- } else {
486
- this.errorLog(`wasn't able to establish BLE Connection, node-switchbot: ${JSON.stringify(switchBotBLE)}`)
487
- await this.BLEPushConnection()
488
- }
489
- } catch (error) {
490
- this.errorLog(`failed to format device ID as MAC, Error: ${error}`)
491
- }
492
- } else {
493
- this.debugLog(`No changes (BLEpushChanges), LockTargetState: ${this.LockMechanism.LockTargetState}, LockCurrentState: ${this.LockMechanism.LockCurrentState}`)
494
- }
495
- }
496
-
497
- async openAPIpushChanges(LatchUnlock?: boolean): Promise<void> {
498
- this.debugLog('openAPIpushChanges')
499
- if ((this.LockMechanism.LockTargetState !== this.accessory.context.LockTargetState) || LatchUnlock) {
500
- // Determine the command based on the LockTargetState or the forceUnlock parameter
501
- const command = LatchUnlock ? 'unlock' : this.LockMechanism.LockTargetState ? 'lock' : 'unlock'
502
- const bodyChange: bodyChange = {
503
- command: `${command}`,
504
- parameter: 'default',
505
- commandType: 'command',
506
- }
507
- this.debugLog(`SwitchBot OpenAPI bodyChange: ${JSON.stringify(bodyChange)}`)
508
- try {
509
- const deviceStatus = await this.pushChangeRequest(bodyChange)
510
- this.debugLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)
511
- if (await this.successfulStatusCodes(deviceStatus)) {
512
- this.debugSuccessLog(`statusCode: ${deviceStatus.statusCode}, deviceStatus: ${JSON.stringify(deviceStatus)}`)
513
- await this.updateHomeKitCharacteristics()
514
- } else {
515
- await this.statusCode(deviceStatus.statusCode)
516
- }
517
- } catch (e: any) {
518
- await this.apiError(e)
519
- this.errorLog(`failed openAPIpushChanges with ${this.device.connectionType} Connection, Error Message: ${JSON.stringify(e.message)}`)
520
- }
521
- } else {
522
- this.debugLog(`No changes (openAPIpushChanges), LockCurrentState: ${this.LockMechanism.LockCurrentState}, TargetPosition: ${this.LockMechanism.LockTargetState}`)
523
- }
524
- }
525
-
526
- /**
527
- * Handle requests to set the value of the "On" characteristic
528
- */
529
- async LockTargetStateSet(value: CharacteristicValue): Promise<void> {
530
- if (this.LockMechanism.LockTargetState !== this.accessory.context.LockTargetState) {
531
- this.infoLog(`Set LockTargetState: ${value}`)
532
- } else {
533
- this.debugLog(`No Changes, LockTargetState: ${value}`)
534
- }
535
-
536
- this.LockMechanism.LockTargetState = value
537
- this.doLockUpdate.next()
538
- }
539
-
540
- /**
541
- * Handle requests to set the value of the "On" characteristic
542
- */
543
- async OnSet(value: CharacteristicValue): Promise<void> {
544
- this.debugLog(`Latch Button Set On: ${value}`)
545
- if (value) {
546
- this.debugLog('Attempting to open the latch')
547
-
548
- this.openAPIpushChanges(value as boolean).then(async () => {
549
- this.debugLog('Latch opened successfully')
550
- this.debugLog(`SwitchService is: ${this.Switch?.Service ? 'available' : 'not available'}`)
551
-
552
- // simulate button press to turn the switch back off
553
- if (this.Switch?.Service) {
554
- const SwitchService = this.Switch.Service
555
- // Simulate a button press by waiting a short period before turning the switch off
556
- setTimeout(async () => {
557
- SwitchService.getCharacteristic(this.hap.Characteristic.On).updateValue(false)
558
- this.debugLog('Latch button switched off automatically.')
559
- }, 500) // 500 ms delay
560
- }
561
- }).catch(async (e: any) => {
562
- // Log the error if the operation failed
563
- this.debugLog(`Error opening latch: ${e.message ?? e}`)
564
- // Ensure we turn the switch back off even in case of an error
565
- if (this.Switch?.Service) {
566
- this.Switch.Service.getCharacteristic(this.hap.Characteristic.On).updateValue(false)
567
- this.debugLog('Latch button switched off after an error.')
568
- }
569
- })
570
- } else {
571
- this.debugLog('Switch is off, nothing to do')
572
- }
573
-
574
- this.Switch!.On = value
575
- this.doLockUpdate.next()
576
- }
577
-
578
- async updateHomeKitCharacteristics(): Promise<void> {
579
- // LockCurrentState
580
- await this.updateCharacteristic(this.LockMechanism.Service, this.hap.Characteristic.LockTargetState, this.LockMechanism.LockTargetState, 'LockTargetState')
581
- // LockCurrentState
582
- await this.updateCharacteristic(this.LockMechanism.Service, this.hap.Characteristic.LockCurrentState, this.LockMechanism.LockCurrentState, 'LockCurrentState')
583
- // ContactSensorState
584
- if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {
585
- await this.updateCharacteristic(this.ContactSensor.Service, this.hap.Characteristic.ContactSensorState, this.ContactSensor.ContactSensorState, 'ContactSensorState')
586
- }
587
- // BatteryLevel
588
- await this.updateCharacteristic(this.Battery.Service, this.hap.Characteristic.BatteryLevel, this.Battery.BatteryLevel, 'BatteryLevel')
589
- // StatusLowBattery
590
- await this.updateCharacteristic(this.Battery.Service, this.hap.Characteristic.StatusLowBattery, this.Battery.StatusLowBattery, 'StatusLowBattery')
591
- }
592
-
593
- async BLEPushConnection() {
594
- if (this.platform.config.credentials?.token && this.device.connectionType === 'BLE/OpenAPI') {
595
- this.warnLog('Using OpenAPI Connection to Push Changes')
596
- await this.openAPIpushChanges()
597
- }
598
- }
599
-
600
- async BLERefreshConnection(switchbot: SwitchBotBLE): Promise<void> {
601
- this.errorLog(`wasn't able to establish BLE Connection, node-switchbot: ${switchbot}`)
602
- if (this.platform.config.credentials?.token && this.device.connectionType === 'BLE/OpenAPI') {
603
- this.warnLog('Using OpenAPI Connection to Refresh Status')
604
- await this.openAPIRefreshStatus()
605
- }
606
- }
607
-
608
- async offlineOff(): Promise<void> {
609
- if (this.device.offline) {
610
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockTargetState, this.hap.Characteristic.LockTargetState.SECURED)
611
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockCurrentState, this.hap.Characteristic.LockCurrentState.SECURED)
612
- if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {
613
- this.ContactSensor.Service.updateCharacteristic(this.hap.Characteristic.ContactSensorState, this.hap.Characteristic.ContactSensorState.CONTACT_DETECTED)
614
- }
615
- }
616
- }
617
-
618
- async apiError(e: any): Promise<void> {
619
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockTargetState, e)
620
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockCurrentState, e)
621
- if (!(this.device as lockConfig).hide_contactsensor && this.ContactSensor?.Service) {
622
- this.ContactSensor.Service.updateCharacteristic(this.hap.Characteristic.ContactSensorState, e)
623
- }
624
- this.Battery.Service.updateCharacteristic(this.hap.Characteristic.BatteryLevel, e)
625
- this.Battery.Service.updateCharacteristic(this.hap.Characteristic.StatusLowBattery, e)
626
- }
627
- }