@switchbot/homebridge-switchbot 5.0.0-beta.70 → 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.
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 +3 -5
  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 +3 -5
  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,778 +0,0 @@
1
- import { irdeviceBase } from './irdevice.js';
2
- /**
3
- * Platform Accessory
4
- * An instance of this class is created for each accessory your platform registers
5
- * Each accessory may expose multiple services of different service types.
6
- */
7
- export class Others extends irdeviceBase {
8
- platform;
9
- // Services
10
- Switch;
11
- GarageDoor;
12
- Door;
13
- Window;
14
- WindowCovering;
15
- LockMechanism;
16
- Faucet;
17
- Fan;
18
- StatefulProgrammableSwitch;
19
- Outlet;
20
- On;
21
- // Config
22
- otherDeviceType;
23
- constructor(platform, accessory, device) {
24
- super(platform, accessory, device);
25
- this.platform = platform;
26
- // default placeholders
27
- this.getOtherConfigSettings(accessory, device);
28
- // deviceType
29
- if (this.otherDeviceType === 'Switch') {
30
- // Set category
31
- accessory.category = 8 /* this.hap.Categories.SWITCH */;
32
- // Initialize Switch Service
33
- accessory.context.Switch = accessory.context.Switch ?? {};
34
- this.Switch = {
35
- Name: accessory.displayName,
36
- Service: accessory.getService(this.hap.Service.Switch) ?? accessory.addService(this.hap.Service.Switch),
37
- };
38
- accessory.context.Switch = this.Switch;
39
- this.debugLog('Displaying as Switch');
40
- // Initialize Switch Characteristics
41
- this.Switch.Service.setCharacteristic(this.hap.Characteristic.Name, this.Switch.Name).getCharacteristic(this.hap.Characteristic.On).onSet(this.OnSet.bind(this));
42
- // Remove other services
43
- this.removeFanService(accessory);
44
- this.removeLockService(accessory);
45
- this.removeDoorService(accessory);
46
- this.removeFaucetService(accessory);
47
- this.removeOutletService(accessory);
48
- this.removeWindowService(accessory);
49
- this.removeGarageDoorService(accessory);
50
- this.removeWindowCoveringService(accessory);
51
- this.removeStatefulProgrammableSwitchService(accessory);
52
- }
53
- else if (this.otherDeviceType === 'GarageDoor') {
54
- // Set category
55
- accessory.category = 4 /* this.hap.Categories.GARAGE_DOOR_OPENER */;
56
- // Initialize GarageDoor Service
57
- accessory.context.GarageDoor = accessory.context.GarageDoor ?? {};
58
- this.GarageDoor = {
59
- Name: accessory.displayName,
60
- Service: accessory.getService(this.hap.Service.GarageDoorOpener) ?? accessory.addService(this.hap.Service.GarageDoorOpener),
61
- };
62
- accessory.context.GarageDoor = this.GarageDoor;
63
- this.debugLog('Displaying as Garage Door Opener');
64
- // Initialize GarageDoor Characteristics
65
- this.GarageDoor.Service.setCharacteristic(this.hap.Characteristic.Name, this.GarageDoor.Name).setCharacteristic(this.hap.Characteristic.ObstructionDetected, false).getCharacteristic(this.hap.Characteristic.TargetDoorState).setProps({
66
- validValues: [0, 100],
67
- minValue: 0,
68
- maxValue: 100,
69
- minStep: 100,
70
- }).onSet(this.OnSet.bind(this));
71
- // Remove other services
72
- this.removeFanService(accessory);
73
- this.removeLockService(accessory);
74
- this.removeDoorService(accessory);
75
- this.removeFaucetService(accessory);
76
- this.removeOutletService(accessory);
77
- this.removeSwitchService(accessory);
78
- this.removeWindowService(accessory);
79
- this.removeWindowCoveringService(accessory);
80
- this.removeStatefulProgrammableSwitchService(accessory);
81
- }
82
- else if (this.otherDeviceType === 'Door') {
83
- // Set category
84
- accessory.category = 12 /* this.hap.Categories.DOOR */;
85
- // Initialize Door Service
86
- accessory.context.Door = accessory.context.Door ?? {};
87
- this.Door = {
88
- Name: accessory.displayName,
89
- Service: accessory.getService(this.hap.Service.Door) ?? accessory.addService(this.hap.Service.Door),
90
- };
91
- accessory.context.Door = this.Door;
92
- this.debugLog('Displaying as Door');
93
- // Initialize Door Characteristics
94
- this.Door.Service.setCharacteristic(this.hap.Characteristic.Name, this.Door.Name).setCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED).getCharacteristic(this.hap.Characteristic.TargetPosition).setProps({
95
- validValues: [0, 100],
96
- minValue: 0,
97
- maxValue: 100,
98
- minStep: 100,
99
- }).onSet(this.OnSet.bind(this));
100
- // Remove other services
101
- this.removeFanService(accessory);
102
- this.removeLockService(accessory);
103
- this.removeOutletService(accessory);
104
- this.removeFaucetService(accessory);
105
- this.removeSwitchService(accessory);
106
- this.removeWindowService(accessory);
107
- this.removeGarageDoorService(accessory);
108
- this.removeWindowCoveringService(accessory);
109
- this.removeStatefulProgrammableSwitchService(accessory);
110
- }
111
- else if (this.otherDeviceType === 'Window') {
112
- // Set category
113
- accessory.category = 13 /* this.hap.Categories.WINDOW */;
114
- // Initialize Window Service
115
- accessory.context.Window = accessory.context.Window ?? {};
116
- this.Window = {
117
- Name: accessory.displayName,
118
- Service: accessory.getService(this.hap.Service.Window) ?? accessory.addService(this.hap.Service.Window),
119
- };
120
- accessory.context.Window = this.Window;
121
- this.debugLog('Displaying as Window');
122
- // Initialize Window Characteristics
123
- this.Window.Service.setCharacteristic(this.hap.Characteristic.Name, this.Window.Name).setCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED).getCharacteristic(this.hap.Characteristic.TargetPosition).setProps({
124
- validValues: [0, 100],
125
- minValue: 0,
126
- maxValue: 100,
127
- minStep: 100,
128
- }).onSet(this.OnSet.bind(this));
129
- // Remove other services
130
- this.removeFanService(accessory);
131
- this.removeLockService(accessory);
132
- this.removeDoorService(accessory);
133
- this.removeOutletService(accessory);
134
- this.removeFaucetService(accessory);
135
- this.removeSwitchService(accessory);
136
- this.removeGarageDoorService(accessory);
137
- this.removeWindowCoveringService(accessory);
138
- this.removeStatefulProgrammableSwitchService(accessory);
139
- }
140
- else if (this.otherDeviceType === 'WindowCovering') {
141
- // Set category
142
- accessory.category = 14 /* this.hap.Categories.WINDOW_COVERING */;
143
- // Initialize WindowCovering Service
144
- accessory.context.WindowCovering = accessory.context.WindowCovering ?? {};
145
- this.WindowCovering = {
146
- Name: accessory.displayName,
147
- Service: accessory.getService(this.hap.Service.WindowCovering) ?? accessory.addService(this.hap.Service.WindowCovering),
148
- };
149
- accessory.context.WindowCovering = this.WindowCovering;
150
- this.debugLog('Displaying as Window Covering');
151
- // Initialize WindowCovering Characteristics
152
- this.WindowCovering.Service.setCharacteristic(this.hap.Characteristic.Name, this.WindowCovering.Name).setCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED).getCharacteristic(this.hap.Characteristic.TargetPosition).setProps({
153
- validValues: [0, 100],
154
- minValue: 0,
155
- maxValue: 100,
156
- minStep: 100,
157
- }).onSet(this.OnSet.bind(this));
158
- // Remove other services
159
- this.removeFanService(accessory);
160
- this.removeLockService(accessory);
161
- this.removeDoorService(accessory);
162
- this.removeOutletService(accessory);
163
- this.removeFaucetService(accessory);
164
- this.removeSwitchService(accessory);
165
- this.removeWindowService(accessory);
166
- this.removeGarageDoorService(accessory);
167
- this.removeStatefulProgrammableSwitchService(accessory);
168
- }
169
- else if (this.otherDeviceType === 'Lock') {
170
- // Set category
171
- accessory.category = 6 /* this.hap.Categories.DOOR_LOCK */;
172
- // Initialize Lock Service
173
- accessory.context.LockMechanism = accessory.context.LockMechanism ?? {};
174
- this.LockMechanism = {
175
- Name: accessory.displayName,
176
- Service: accessory.getService(this.hap.Service.LockMechanism) ?? accessory.addService(this.hap.Service.LockMechanism),
177
- };
178
- accessory.context.LockMechanism = this.LockMechanism;
179
- this.debugLog('Displaying as Lock');
180
- // Initialize Lock Characteristics
181
- this.LockMechanism.Service.setCharacteristic(this.hap.Characteristic.Name, this.LockMechanism.Name).setCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED).getCharacteristic(this.hap.Characteristic.LockTargetState).onSet(this.OnSet.bind(this));
182
- // Remove other services
183
- this.removeFanService(accessory);
184
- this.removeDoorService(accessory);
185
- this.removeOutletService(accessory);
186
- this.removeSwitchService(accessory);
187
- this.removeFaucetService(accessory);
188
- this.removeWindowService(accessory);
189
- this.removeGarageDoorService(accessory);
190
- this.removeWindowCoveringService(accessory);
191
- this.removeStatefulProgrammableSwitchService(accessory);
192
- }
193
- else if (this.otherDeviceType === 'Faucet') {
194
- // Set category
195
- accessory.category = 29 /* this.hap.Categories.FAUCET */;
196
- // Initialize Faucet Service
197
- accessory.context.Faucet = accessory.context.Faucet ?? {};
198
- this.Faucet = {
199
- Name: accessory.displayName,
200
- Service: accessory.getService(this.hap.Service.Faucet) ?? accessory.addService(this.hap.Service.Faucet),
201
- };
202
- accessory.context.Faucet = this.Faucet;
203
- this.debugLog('Displaying as Faucet');
204
- // Initialize Faucet Characteristics
205
- this.Faucet.Service.setCharacteristic(this.hap.Characteristic.Name, this.Faucet.Name).getCharacteristic(this.hap.Characteristic.Active).onSet(this.OnSet.bind(this));
206
- // Remove other services
207
- this.removeFanService(accessory);
208
- this.removeLockService(accessory);
209
- this.removeDoorService(accessory);
210
- this.removeOutletService(accessory);
211
- this.removeSwitchService(accessory);
212
- this.removeWindowService(accessory);
213
- this.removeGarageDoorService(accessory);
214
- this.removeWindowCoveringService(accessory);
215
- this.removeStatefulProgrammableSwitchService(accessory);
216
- }
217
- else if (this.otherDeviceType === 'Fan') {
218
- // Set category
219
- accessory.category = 3 /* this.hap.Categories.FAN */;
220
- // Initialize Fan Service
221
- accessory.context.Fan = accessory.context.Fan ?? {};
222
- this.Fan = {
223
- Name: accessory.displayName,
224
- Service: accessory.getService(this.hap.Service.Fanv2) ?? accessory.addService(this.hap.Service.Fanv2),
225
- };
226
- accessory.context.Fan = this.Fan;
227
- this.debugLog('Displaying as Fan');
228
- // Initialize Fan Characteristics
229
- this.Fan.Service.setCharacteristic(this.hap.Characteristic.Name, this.Fan.Name).getCharacteristic(this.hap.Characteristic.Active).onSet(this.OnSet.bind(this));
230
- // Remove other services
231
- this.removeLockService(accessory);
232
- this.removeDoorService(accessory);
233
- this.removeFaucetService(accessory);
234
- this.removeOutletService(accessory);
235
- this.removeSwitchService(accessory);
236
- this.removeWindowService(accessory);
237
- this.removeGarageDoorService(accessory);
238
- this.removeWindowCoveringService(accessory);
239
- this.removeStatefulProgrammableSwitchService(accessory);
240
- }
241
- else if (this.otherDeviceType === 'Stateful') {
242
- // Set category
243
- accessory.category = 15 /* this.hap.Categories.PROGRAMMABLE_SWITCH */;
244
- // Initialize StatefulProgrammableSwitch Service
245
- accessory.context.StatefulProgrammableSwitch = accessory.context.StatefulProgrammableSwitch ?? {};
246
- this.StatefulProgrammableSwitch = {
247
- Name: accessory.displayName,
248
- Service: accessory.getService(this.hap.Service.StatefulProgrammableSwitch) ?? accessory.addService(this.hap.Service.StatefulProgrammableSwitch),
249
- };
250
- accessory.context.StatefulProgrammableSwitch = this.StatefulProgrammableSwitch;
251
- this.debugLog('Displaying as Stateful Programmable Switch');
252
- // Initialize StatefulProgrammableSwitch Characteristics
253
- this.StatefulProgrammableSwitch.Service.setCharacteristic(this.hap.Characteristic.Name, this.StatefulProgrammableSwitch.Name).getCharacteristic(this.hap.Characteristic.ProgrammableSwitchOutputState).onSet(this.OnSet.bind(this));
254
- // Remove other services
255
- this.removeFanService(accessory);
256
- this.removeLockService(accessory);
257
- this.removeDoorService(accessory);
258
- this.removeFaucetService(accessory);
259
- this.removeOutletService(accessory);
260
- this.removeSwitchService(accessory);
261
- this.removeWindowService(accessory);
262
- this.removeGarageDoorService(accessory);
263
- this.removeWindowCoveringService(accessory);
264
- }
265
- else if (this.otherDeviceType === 'Outlet') {
266
- // Set category
267
- accessory.category = 7 /* this.hap.Categories.OUTLET */;
268
- // Initialize Switch property
269
- accessory.context.Outlet = accessory.context.Outlet ?? {};
270
- this.Outlet = {
271
- Name: accessory.displayName,
272
- Service: accessory.getService(this.hap.Service.Outlet) ?? accessory.addService(this.hap.Service.Outlet),
273
- };
274
- accessory.context.Outlet = this.Outlet;
275
- this.debugLog('Displaying as Outlet');
276
- // Initialize Outlet Characteristics
277
- this.Outlet.Service.setCharacteristic(this.hap.Characteristic.Name, this.Outlet.Name).getCharacteristic(this.hap.Characteristic.On).onSet(this.OnSet.bind(this));
278
- // Remove other services
279
- this.removeFanService(accessory);
280
- this.removeLockService(accessory);
281
- this.removeDoorService(accessory);
282
- this.removeFaucetService(accessory);
283
- this.removeSwitchService(accessory);
284
- this.removeWindowService(accessory);
285
- this.removeGarageDoorService(accessory);
286
- this.removeWindowCoveringService(accessory);
287
- this.removeStatefulProgrammableSwitchService(accessory);
288
- }
289
- else {
290
- this.errorLog('Device Type not set');
291
- }
292
- }
293
- /**
294
- * Handle requests to set the "On" characteristic
295
- */
296
- async OnSet(value) {
297
- if (this.otherDeviceType === 'Switch') {
298
- if (this.Switch) {
299
- this.debugLog(`Set On: ${value}`);
300
- this.On = value !== false;
301
- }
302
- }
303
- else if (this.otherDeviceType === 'GarageDoor') {
304
- if (this.GarageDoor) {
305
- this.debugLog(`Set TargetDoorState: ${value}`);
306
- this.On = value !== this.hap.Characteristic.TargetDoorState.CLOSED;
307
- }
308
- }
309
- else if (this.otherDeviceType === 'Door') {
310
- if (this.Door) {
311
- this.debugLog(`Set TargetPosition: ${value}`);
312
- this.On = value !== 0;
313
- }
314
- }
315
- else if (this.otherDeviceType === 'Window') {
316
- if (this.Window) {
317
- this.debugLog(`Set TargetPosition: ${value}`);
318
- this.On = value !== 0;
319
- }
320
- }
321
- else if (this.otherDeviceType === 'WindowCovering') {
322
- if (this.WindowCovering) {
323
- this.debugLog(`Set TargetPosition: ${value}`);
324
- this.On = value !== 0;
325
- }
326
- }
327
- else if (this.otherDeviceType === 'Lock') {
328
- if (this.LockMechanism) {
329
- this.debugLog(`Set LockTargetState: ${value}`);
330
- this.On = value !== this.hap.Characteristic.LockTargetState.SECURED;
331
- }
332
- }
333
- else if (this.otherDeviceType === 'Faucet') {
334
- if (this.Faucet) {
335
- this.debugLog(`Set Active: ${value}`);
336
- this.On = value !== this.hap.Characteristic.Active.INACTIVE;
337
- }
338
- }
339
- else if (this.otherDeviceType === 'Stateful') {
340
- if (this.StatefulProgrammableSwitch) {
341
- this.debugLog(`Set ProgrammableSwitchOutputState: ${value}`);
342
- this.On = value !== 0;
343
- }
344
- }
345
- else {
346
- if (this.Outlet) {
347
- this.debugLog(`Set On: ${value}`);
348
- this.On = value !== false;
349
- }
350
- }
351
- // pushChanges
352
- if (this.On === true) {
353
- await this.pushOnChanges(this.On);
354
- }
355
- else {
356
- await this.pushOffChanges(this.On);
357
- }
358
- }
359
- /**
360
- * Pushes the requested changes to the SwitchBot API
361
- * deviceType commandType Command command parameter Description
362
- * Other - "command" "turnOff" "default" = set to OFF state
363
- * Other - "command" "turnOn" "default" = set to ON state
364
- * Other - "command" "volumeAdd" "default" = volume up
365
- * Other - "command" "volumeSub" "default" = volume down
366
- * Other - "command" "channelAdd" "default" = next channel
367
- * Other - "command" "channelSub" "default" = previous channel
368
- */
369
- async pushOnChanges(On) {
370
- this.debugLog(`pushOnChanges On: ${On}, disablePushOn: ${this.deviceDisablePushOn}, customize: ${this.device.customize}, customOn: ${this.device.customOn}`);
371
- if (this.device.customize) {
372
- if (On === true && !this.deviceDisablePushOn) {
373
- const commandType = await this.commandType();
374
- const command = await this.commandOn();
375
- const bodyChange = {
376
- command,
377
- parameter: 'default',
378
- commandType,
379
- };
380
- await this.pushChanges(bodyChange);
381
- }
382
- }
383
- else {
384
- this.errorLog('On Command not set');
385
- }
386
- }
387
- async pushOffChanges(On) {
388
- this.debugLog(`pushOffChanges On: ${On}, disablePushOff: ${this.deviceDisablePushOff}, customize: ${this.device.customize}, customOff: ${this.device.customOff}`);
389
- if (this.device.customize) {
390
- if (On === false && !this.deviceDisablePushOff) {
391
- const commandType = await this.commandType();
392
- const command = await this.commandOff();
393
- const bodyChange = {
394
- command,
395
- parameter: 'default',
396
- commandType,
397
- };
398
- await this.pushChanges(bodyChange);
399
- }
400
- }
401
- else {
402
- this.errorLog('Off Command not set.');
403
- }
404
- }
405
- async pushChanges(bodyChange) {
406
- this.debugLog('pushChanges');
407
- if (this.device.connectionType === 'OpenAPI') {
408
- this.infoLog(`Sending request to SwitchBot API, body: ${JSON.stringify(bodyChange)}`);
409
- try {
410
- const deviceStatus = await this.pushChangeRequest(bodyChange);
411
- await this.pushStatusCodes(deviceStatus);
412
- if (await this.successfulStatusCodes(deviceStatus)) {
413
- await this.successfulPushChange(deviceStatus, bodyChange);
414
- await this.updateHomeKitCharacteristics();
415
- }
416
- else {
417
- await this.statusCode(deviceStatus.statusCode);
418
- }
419
- }
420
- catch (e) {
421
- await this.apiError(e);
422
- await this.pushChangeError(e);
423
- }
424
- }
425
- else {
426
- this.warnLog(`Connection Type: ${this.device.connectionType}, commands will not be sent to OpenAPI`);
427
- }
428
- }
429
- async updateHomeKitCharacteristics() {
430
- this.debugLog('updateHomeKitCharacteristics');
431
- // State
432
- if (this.otherDeviceType === 'Switch' && this.Switch) {
433
- if (this.On === undefined) {
434
- this.debugLog(`On: ${this.On}`);
435
- }
436
- else {
437
- this.Switch.Service.updateCharacteristic(this.hap.Characteristic.On, this.On);
438
- this.debugLog(`updateCharacteristic On: ${this.On}`);
439
- }
440
- }
441
- else if (this.otherDeviceType === 'GarageDoor' && this.GarageDoor) {
442
- if (this.On === undefined) {
443
- this.debugLog(`On: ${this.On}`);
444
- }
445
- else {
446
- if (this.On) {
447
- this.GarageDoor.Service.updateCharacteristic(this.hap.Characteristic.TargetDoorState, this.hap.Characteristic.TargetDoorState.OPEN);
448
- this.GarageDoor.Service.updateCharacteristic(this.hap.Characteristic.CurrentDoorState, this.hap.Characteristic.CurrentDoorState.OPEN);
449
- this.debugLog(`updateCharacteristic TargetDoorState: Open, CurrentDoorState: Open (${this.On})`);
450
- }
451
- else {
452
- this.GarageDoor.Service.updateCharacteristic(this.hap.Characteristic.TargetDoorState, this.hap.Characteristic.TargetDoorState.CLOSED);
453
- this.GarageDoor.Service.updateCharacteristic(this.hap.Characteristic.CurrentDoorState, this.hap.Characteristic.CurrentDoorState.CLOSED);
454
- this.debugLog(`updateCharacteristicc TargetDoorState: Closed, CurrentDoorState: Closed (${this.On})`);
455
- }
456
- }
457
- this.debugLog(`Garage Door On: ${this.On}`);
458
- }
459
- else if (this.otherDeviceType === 'Door' && this.Door) {
460
- if (this.On === undefined) {
461
- this.debugLog(`On: ${this.On}`);
462
- }
463
- else {
464
- if (this.On) {
465
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, 100);
466
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, 100);
467
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED);
468
- this.debugLog(`updateCharacteristicc TargetPosition: 100, CurrentPosition: 100 (${this.On})`);
469
- }
470
- else {
471
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, 0);
472
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, 0);
473
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED);
474
- this.debugLog(`updateCharacteristicc TargetPosition: 0, CurrentPosition: 0 (${this.On})`);
475
- }
476
- }
477
- this.debugLog(`Door On: ${this.On}`);
478
- }
479
- else if (this.otherDeviceType === 'Window' && this.Window) {
480
- if (this.On === undefined) {
481
- this.debugLog(`On: ${this.On}`);
482
- }
483
- else {
484
- if (this.On) {
485
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, 100);
486
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, 100);
487
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED);
488
- this.debugLog(`updateCharacteristicc TargetPosition: 100, CurrentPosition: 100 (${this.On})`);
489
- }
490
- else {
491
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, 0);
492
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, 0);
493
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED);
494
- this.debugLog(`updateCharacteristicc TargetPosition: 0, CurrentPosition: 0 (${this.On})`);
495
- }
496
- }
497
- this.debugLog(`Window On: ${this.On}`);
498
- }
499
- else if (this.otherDeviceType === 'WindowCovering' && this.WindowCovering) {
500
- if (this.On === undefined) {
501
- this.debugLog(`On: ${this.On}`);
502
- }
503
- else {
504
- if (this.On) {
505
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, 100);
506
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, 100);
507
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED);
508
- this.debugLog(`updateCharacteristicc TargetPosition: 100, CurrentPosition: 100 (${this.On})`);
509
- }
510
- else {
511
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, 0);
512
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, 0);
513
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.PositionState, this.hap.Characteristic.PositionState.STOPPED);
514
- this.debugLog(`updateCharacteristicc TargetPosition: 0, CurrentPosition: 0 (${this.On})`);
515
- }
516
- }
517
- this.debugLog(`Window Covering On: ${this.On}`);
518
- }
519
- else if (this.otherDeviceType === 'Lock' && this.LockMechanism) {
520
- if (this.On === undefined) {
521
- this.debugLog(`On: ${this.On}`);
522
- }
523
- else {
524
- if (this.On) {
525
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockTargetState, this.hap.Characteristic.LockTargetState.UNSECURED);
526
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockCurrentState, this.hap.Characteristic.LockCurrentState.UNSECURED);
527
- this.debugLog(`updateCharacteristicc LockTargetState: UNSECURED, LockCurrentState: UNSECURED (${this.On})`);
528
- }
529
- else {
530
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockTargetState, this.hap.Characteristic.LockTargetState.SECURED);
531
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockCurrentState, this.hap.Characteristic.LockCurrentState.SECURED);
532
- this.debugLog(`updateCharacteristic LockTargetState: SECURED, LockCurrentState: SECURED (${this.On})`);
533
- }
534
- }
535
- this.debugLog(`Lock On: ${this.On}`);
536
- }
537
- else if (this.otherDeviceType === 'Faucet' && this.Faucet) {
538
- if (this.On === undefined) {
539
- this.debugLog(`On: ${this.On}`);
540
- }
541
- else {
542
- if (this.On) {
543
- this.Faucet.Service.updateCharacteristic(this.hap.Characteristic.Active, this.hap.Characteristic.Active.ACTIVE);
544
- this.debugLog(`updateCharacteristic Active: ${this.On}`);
545
- }
546
- else {
547
- this.Faucet.Service.updateCharacteristic(this.hap.Characteristic.Active, this.hap.Characteristic.Active.INACTIVE);
548
- this.debugLog(`updateCharacteristic Active: ${this.On}`);
549
- }
550
- }
551
- this.debugLog(`Faucet On: ${this.On}`);
552
- }
553
- else if (this.otherDeviceType === 'Fan' && this.Fan) {
554
- if (this.On === undefined) {
555
- this.debugLog(`On: ${this.On}`);
556
- }
557
- else {
558
- if (this.On) {
559
- this.Fan.Service.updateCharacteristic(this.hap.Characteristic.Active, this.hap.Characteristic.Active.ACTIVE);
560
- this.debugLog(`updateCharacteristic Active: ${this.On}`);
561
- }
562
- else {
563
- this.Fan.Service.updateCharacteristic(this.hap.Characteristic.Active, this.hap.Characteristic.Active.INACTIVE);
564
- this.debugLog(`updateCharacteristic Active: ${this.On}`);
565
- }
566
- }
567
- this.debugLog(`Fan On: ${this.On}`);
568
- }
569
- else if (this.otherDeviceType === 'Stateful' && this.StatefulProgrammableSwitch) {
570
- if (this.On === undefined) {
571
- this.debugLog(`On: ${this.On}`);
572
- }
573
- else {
574
- if (this.On) {
575
- this.StatefulProgrammableSwitch.Service.updateCharacteristic(this.hap.Characteristic.ProgrammableSwitchEvent, this.hap.Characteristic.ProgrammableSwitchEvent.SINGLE_PRESS);
576
- this.StatefulProgrammableSwitch.Service.updateCharacteristic(this.hap.Characteristic.ProgrammableSwitchOutputState, 1);
577
- this.debugLog(`updateCharacteristic ProgrammableSwitchEvent: ProgrammableSwitchOutputState: (${this.On})`);
578
- }
579
- else {
580
- this.StatefulProgrammableSwitch.Service.updateCharacteristic(this.hap.Characteristic.ProgrammableSwitchEvent, this.hap.Characteristic.ProgrammableSwitchEvent.SINGLE_PRESS);
581
- this.StatefulProgrammableSwitch.Service.updateCharacteristic(this.hap.Characteristic.ProgrammableSwitchOutputState, 0);
582
- this.debugLog(`updateCharacteristic ProgrammableSwitchEvent: ProgrammableSwitchOutputState: (${this.On})`);
583
- }
584
- }
585
- this.debugLog(`StatefulProgrammableSwitch On: ${this.On}`);
586
- }
587
- else if (this.otherDeviceType === 'Outlet' && this.Outlet) {
588
- if (this.On === undefined) {
589
- this.debugLog(`On: ${this.On}`);
590
- }
591
- else {
592
- this.Outlet.Service.updateCharacteristic(this.hap.Characteristic.On, this.On);
593
- this.debugLog(`updateCharacteristic On: ${this.On}`);
594
- }
595
- }
596
- else {
597
- this.errorLog(`otherDeviceType: ${this.otherDeviceType}, On: ${this.On}`);
598
- }
599
- }
600
- async apiError(e) {
601
- if (this.otherDeviceType === 'GarageDoor') {
602
- if (this.GarageDoor) {
603
- this.GarageDoor.Service.updateCharacteristic(this.hap.Characteristic.TargetDoorState, e);
604
- this.GarageDoor.Service.updateCharacteristic(this.hap.Characteristic.CurrentDoorState, e);
605
- this.GarageDoor.Service.updateCharacteristic(this.hap.Characteristic.ObstructionDetected, e);
606
- }
607
- }
608
- else if (this.otherDeviceType === 'Door') {
609
- if (this.Door) {
610
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, e);
611
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, e);
612
- this.Door.Service.updateCharacteristic(this.hap.Characteristic.PositionState, e);
613
- }
614
- }
615
- else if (this.otherDeviceType === 'Window') {
616
- if (this.Window) {
617
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, e);
618
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, e);
619
- this.Window.Service.updateCharacteristic(this.hap.Characteristic.PositionState, e);
620
- }
621
- }
622
- else if (this.otherDeviceType === 'WindowCovering') {
623
- if (this.WindowCovering) {
624
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.TargetPosition, e);
625
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.CurrentPosition, e);
626
- this.WindowCovering.Service.updateCharacteristic(this.hap.Characteristic.PositionState, e);
627
- }
628
- }
629
- else if (this.otherDeviceType === 'Lock') {
630
- if (this.LockMechanism) {
631
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockTargetState, e);
632
- this.LockMechanism.Service.updateCharacteristic(this.hap.Characteristic.LockCurrentState, e);
633
- }
634
- }
635
- else if (this.otherDeviceType === 'Faucet') {
636
- if (this.Faucet) {
637
- this.Faucet.Service.updateCharacteristic(this.hap.Characteristic.Active, e);
638
- }
639
- }
640
- else if (this.otherDeviceType === 'Fan') {
641
- if (this.Fan) {
642
- this.Fan.Service.updateCharacteristic(this.hap.Characteristic.On, e);
643
- }
644
- }
645
- else if (this.otherDeviceType === 'Stateful') {
646
- if (this.StatefulProgrammableSwitch) {
647
- this.StatefulProgrammableSwitch.Service.updateCharacteristic(this.hap.Characteristic.ProgrammableSwitchEvent, e);
648
- this.StatefulProgrammableSwitch.Service.updateCharacteristic(this.hap.Characteristic.ProgrammableSwitchOutputState, e);
649
- }
650
- }
651
- else if (this.otherDeviceType === 'Switch') {
652
- if (this.Switch) {
653
- this.Switch.Service.updateCharacteristic(this.hap.Characteristic.On, e);
654
- }
655
- }
656
- else {
657
- if (this.Outlet) {
658
- this.Outlet.Service.updateCharacteristic(this.hap.Characteristic.On, e);
659
- }
660
- }
661
- }
662
- async removeOutletService(accessory) {
663
- // If Outlet.Service still present, then remove first
664
- accessory.context.Outlet = accessory.context.Outlet ?? {};
665
- this.Outlet = {
666
- Name: accessory.displayName,
667
- Service: accessory.getService(this.hap.Service.Outlet),
668
- };
669
- accessory.context.Outlet = this.Outlet;
670
- this.warnLog('Removing any leftover Outlet Service');
671
- accessory.removeService(this.Outlet.Service);
672
- }
673
- async removeGarageDoorService(accessory) {
674
- // If GarageDoor.Service still present, then remove first
675
- accessory.context.GarageDoor = accessory.context.GarageDoor ?? {};
676
- this.GarageDoor = {
677
- Name: accessory.displayName,
678
- Service: accessory.getService(this.hap.Service.GarageDoorOpener),
679
- };
680
- accessory.context.GarageDoor = this.GarageDoor;
681
- this.warnLog('Removing any leftover Garage Door Service');
682
- accessory.removeService(this.GarageDoor.Service);
683
- }
684
- async removeDoorService(accessory) {
685
- // If Door.Service still present, then remove first
686
- accessory.context.Door = accessory.context.Door ?? {};
687
- this.Door = {
688
- Name: accessory.displayName,
689
- Service: accessory.getService(this.hap.Service.Door),
690
- };
691
- accessory.context.Door = this.Door;
692
- this.warnLog('Removing any leftover Door Service');
693
- accessory.removeService(this.Door.Service);
694
- }
695
- async removeLockService(accessory) {
696
- // If Lock.Service still present, then remove first
697
- accessory.context.LockMechanism = accessory.context.LockMechanism ?? {};
698
- this.LockMechanism = {
699
- Name: accessory.displayName,
700
- Service: accessory.getService(this.hap.Service.LockMechanism),
701
- };
702
- accessory.context.LockMechanism = this.LockMechanism;
703
- this.warnLog('Removing any leftover Lock Service');
704
- accessory.removeService(this.LockMechanism.Service);
705
- }
706
- async removeFaucetService(accessory) {
707
- // If Faucet.Service still present, then remove first
708
- accessory.context.Faucet = accessory.context.Faucet ?? {};
709
- this.Faucet = {
710
- Name: accessory.displayName,
711
- Service: accessory.getService(this.hap.Service.Faucet),
712
- };
713
- accessory.context.Faucet = this.Faucet;
714
- this.warnLog('Removing any leftover Faucet Service');
715
- accessory.removeService(this.Faucet.Service);
716
- }
717
- async removeFanService(accessory) {
718
- // If Fan Service still present, then remove first
719
- accessory.context.Fan = accessory.context.Fan ?? {};
720
- this.Fan = {
721
- Name: accessory.displayName,
722
- Service: accessory.getService(this.hap.Service.Fanv2),
723
- };
724
- accessory.context.Fan = this.Fan;
725
- this.warnLog('Removing any leftover Fan Service');
726
- accessory.removeService(this.Fan.Service);
727
- }
728
- async removeWindowService(accessory) {
729
- // If Window.Service still present, then remove first
730
- accessory.context.Window = accessory.context.Window ?? {};
731
- this.Window = {
732
- Name: accessory.displayName,
733
- Service: accessory.getService(this.hap.Service.Window),
734
- };
735
- accessory.context.Window = this.Window;
736
- this.warnLog('Removing any leftover Window Service');
737
- accessory.removeService(this.Window.Service);
738
- }
739
- async removeWindowCoveringService(accessory) {
740
- // If WindowCovering.Service still present, then remove first
741
- accessory.context.WindowCovering = accessory.context.WindowCovering ?? {};
742
- this.WindowCovering = {
743
- Name: accessory.displayName,
744
- Service: accessory.getService(this.hap.Service.WindowCovering),
745
- };
746
- accessory.context.WindowCovering = this.WindowCovering;
747
- this.warnLog('Removing any leftover Window Covering Service');
748
- accessory.removeService(this.WindowCovering.Service);
749
- }
750
- async removeStatefulProgrammableSwitchService(accessory) {
751
- // If StatefulProgrammableSwitch.Service still present, then remove first
752
- accessory.context.StatefulProgrammableSwitch = accessory.context.StatefulProgrammableSwitch ?? {};
753
- this.StatefulProgrammableSwitch = {
754
- Name: accessory.displayName,
755
- Service: accessory.getService(this.hap.Service.StatefulProgrammableSwitch),
756
- };
757
- accessory.context.StatefulProgrammableSwitch = this.StatefulProgrammableSwitch;
758
- this.warnLog('Removing any leftover Stateful Programmable Switch Service');
759
- accessory.removeService(this.StatefulProgrammableSwitch.Service);
760
- }
761
- async removeSwitchService(accessory) {
762
- // If Switch.Service still present, then remove first
763
- accessory.context.Switch = accessory.context.Switch ?? {};
764
- this.Switch = {
765
- Name: accessory.displayName,
766
- Service: accessory.getService(this.hap.Service.Switch),
767
- };
768
- accessory.context.Switch = this.Switch;
769
- this.warnLog('Removing any leftover Switch Service');
770
- accessory.removeService(this.Switch.Service);
771
- }
772
- async getOtherConfigSettings(accessory, device) {
773
- this.otherDeviceType = device.type ?? 'Outlet';
774
- const deviceType = device.type ? 'Device Config' : 'Default';
775
- this.debugLog(`Use ${deviceType} Device Type: ${this.otherDeviceType}`);
776
- }
777
- }
778
- //# sourceMappingURL=other.js.map