@ray-js/lock-sdk 1.1.3-beta.9 → 1.2.0-beta.1

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/lib/api/ble.d.ts +57 -0
  2. package/lib/api/ble.js +46 -0
  3. package/lib/api/fit.d.ts +203 -0
  4. package/lib/api/fit.js +158 -0
  5. package/lib/api/index.d.ts +1 -1
  6. package/lib/api/index.js +10 -0
  7. package/lib/api/linkage.js +6 -0
  8. package/lib/api/lock.d.ts +4 -2
  9. package/lib/api/lock.js +24 -0
  10. package/lib/api/log.d.ts +49 -22
  11. package/lib/api/log.js +21 -0
  12. package/lib/api/request.d.ts +5 -2
  13. package/lib/api/request.js +34 -2
  14. package/lib/api/screen.d.ts +110 -0
  15. package/lib/api/screen.js +52 -0
  16. package/lib/api/setting.js +2 -0
  17. package/lib/api/temp.d.ts +24 -3
  18. package/lib/api/temp.js +27 -0
  19. package/lib/api/user.d.ts +35 -1
  20. package/lib/api/user.js +24 -0
  21. package/lib/api/video.d.ts +27 -0
  22. package/lib/api/video.js +21 -0
  23. package/lib/api/voice-file.d.ts +14 -0
  24. package/lib/api/voice-file.js +18 -0
  25. package/lib/bootstrap/bootstrap-lock-instance.d.ts +7 -0
  26. package/lib/bootstrap/bootstrap-lock-instance.js +16 -0
  27. package/lib/bootstrap/bootstrap.d.ts +4 -0
  28. package/lib/bootstrap/bootstrap.js +53 -0
  29. package/lib/bootstrap/lock-instance-runtime-ref.d.ts +3 -0
  30. package/lib/bootstrap/lock-instance-runtime-ref.js +7 -0
  31. package/lib/bootstrap/primary-instance.d.ts +6 -0
  32. package/lib/bootstrap/primary-instance.js +24 -0
  33. package/lib/bootstrap/resolve-runtime-from-export-this.d.ts +5 -0
  34. package/lib/bootstrap/resolve-runtime-from-export-this.js +29 -0
  35. package/lib/bootstrap/top-level-runtime.d.ts +2 -0
  36. package/lib/bootstrap/top-level-runtime.js +9 -0
  37. package/lib/config/dp-code/index.d.ts +100 -67
  38. package/lib/config/dp-code/index.js +33 -1
  39. package/lib/config/dp-map/ble-check-code.d.ts +41 -0
  40. package/lib/config/dp-map/ble-check-code.js +55 -0
  41. package/lib/config/dp-map/ble-key-fit.d.ts +328 -0
  42. package/lib/config/dp-map/ble-key-fit.js +33 -0
  43. package/lib/config/dp-map/ble-sync.d.ts +2 -2
  44. package/lib/config/dp-map/ble-sync.js +2 -2
  45. package/lib/config/dp-map/ble-unlock-check.d.ts +42 -0
  46. package/lib/config/dp-map/ble-unlock-check.js +59 -0
  47. package/lib/config/dp-map/ble-voice-data.d.ts +16 -0
  48. package/lib/config/dp-map/ble-voice-data.js +7 -0
  49. package/lib/config/dp-map/bluetooth-unlock.d.ts +10 -0
  50. package/lib/config/dp-map/bluetooth-unlock.js +16 -0
  51. package/lib/config/dp-map/registry.d.ts +1137 -0
  52. package/lib/config/dp-map/registry.js +110 -0
  53. package/lib/config/dp-map/sync-method-fit.d.ts +3 -0
  54. package/lib/config/dp-map/sync-method-fit.js +36 -0
  55. package/lib/config/dp-map/temp-pwd-fit.d.ts +441 -0
  56. package/lib/config/dp-map/temp-pwd-fit.js +73 -0
  57. package/lib/config/dp-map/unlock-method-fit.d.ts +302 -0
  58. package/lib/config/dp-map/unlock-method-fit.js +62 -0
  59. package/lib/config/dp-map/unlock-method.d.ts +345 -1
  60. package/lib/config/dp-map/unlock-method.js +37 -1
  61. package/lib/constant.d.ts +5 -0
  62. package/lib/constant.js +6 -0
  63. package/lib/entries/ble/bootstrap/bootstrap-lock-instance.d.ts +7 -0
  64. package/lib/entries/ble/bootstrap/bootstrap-lock-instance.js +12 -0
  65. package/lib/entries/ble/bootstrap/bootstrap.d.ts +4 -0
  66. package/lib/entries/ble/bootstrap/bootstrap.js +53 -0
  67. package/lib/entries/ble/bootstrap/lock-instance-runtime-ref.d.ts +3 -0
  68. package/lib/entries/ble/bootstrap/lock-instance-runtime-ref.js +7 -0
  69. package/lib/entries/ble/bootstrap/primary-instance.d.ts +6 -0
  70. package/lib/entries/ble/bootstrap/primary-instance.js +24 -0
  71. package/lib/entries/ble/bootstrap/resolve-runtime-from-export-this.d.ts +5 -0
  72. package/lib/entries/ble/bootstrap/resolve-runtime-from-export-this.js +29 -0
  73. package/lib/entries/ble/bootstrap/top-level-runtime.d.ts +2 -0
  74. package/lib/entries/ble/bootstrap/top-level-runtime.js +9 -0
  75. package/lib/entries/ble/build-instance.d.ts +9 -0
  76. package/lib/entries/ble/build-instance.js +50 -0
  77. package/lib/entries/ble/exports/capability.d.ts +6 -0
  78. package/lib/entries/ble/exports/capability.js +17 -0
  79. package/lib/entries/ble/exports/config.d.ts +3 -0
  80. package/lib/entries/ble/exports/config.js +5 -0
  81. package/lib/entries/ble/exports/dp.d.ts +9 -0
  82. package/lib/entries/ble/exports/dp.js +13 -0
  83. package/lib/entries/ble/exports/index.d.ts +16 -0
  84. package/lib/entries/ble/exports/index.js +16 -0
  85. package/lib/entries/ble/exports/linkage.d.ts +5 -0
  86. package/lib/entries/ble/exports/linkage.js +15 -0
  87. package/lib/entries/ble/exports/log.d.ts +9 -0
  88. package/lib/entries/ble/exports/log.js +21 -0
  89. package/lib/entries/ble/exports/media.d.ts +4 -0
  90. package/lib/entries/ble/exports/media.js +12 -0
  91. package/lib/entries/ble/exports/misc.d.ts +19 -0
  92. package/lib/entries/ble/exports/misc.js +30 -0
  93. package/lib/entries/ble/exports/offline-dps.d.ts +8 -0
  94. package/lib/entries/ble/exports/offline-dps.js +24 -0
  95. package/lib/entries/ble/exports/open/do-open-close-action.d.ts +2 -0
  96. package/lib/entries/ble/exports/open/do-open-close-action.js +36 -0
  97. package/lib/entries/ble/exports/open/index.d.ts +18 -0
  98. package/lib/entries/ble/exports/open/index.js +45 -0
  99. package/lib/entries/ble/exports/signal.d.ts +6 -0
  100. package/lib/entries/ble/exports/signal.js +14 -0
  101. package/lib/entries/ble/exports/sleep.d.ts +13 -0
  102. package/lib/entries/ble/exports/sleep.js +31 -0
  103. package/lib/entries/ble/exports/state.d.ts +6 -0
  104. package/lib/entries/ble/exports/state.js +19 -0
  105. package/lib/entries/ble/exports/temporary.d.ts +31 -0
  106. package/lib/entries/ble/exports/temporary.js +91 -0
  107. package/lib/entries/ble/exports/unlock/sync.d.ts +1 -0
  108. package/lib/entries/ble/exports/unlock/sync.js +5 -0
  109. package/lib/entries/ble/exports/unlock-method.d.ts +19 -0
  110. package/lib/entries/ble/exports/unlock-method.js +58 -0
  111. package/lib/entries/ble/exports/user/index.d.ts +23 -0
  112. package/lib/entries/ble/exports/user/index.js +22 -0
  113. package/lib/entries/ble/exports/user/sync.d.ts +1 -0
  114. package/lib/entries/ble/exports/user/sync.js +5 -0
  115. package/lib/entries/ble/index.d.ts +8 -0
  116. package/lib/entries/ble/index.js +39 -0
  117. package/lib/entries/fit/bootstrap/bootstrap-lock-instance.d.ts +7 -0
  118. package/lib/entries/fit/bootstrap/bootstrap-lock-instance.js +12 -0
  119. package/lib/entries/fit/bootstrap/bootstrap.d.ts +4 -0
  120. package/lib/entries/fit/bootstrap/bootstrap.js +69 -0
  121. package/lib/entries/fit/bootstrap/lock-instance-runtime-ref.d.ts +3 -0
  122. package/lib/entries/fit/bootstrap/lock-instance-runtime-ref.js +7 -0
  123. package/lib/entries/fit/bootstrap/primary-instance.d.ts +6 -0
  124. package/lib/entries/fit/bootstrap/primary-instance.js +24 -0
  125. package/lib/entries/fit/bootstrap/resolve-runtime-from-export-this.d.ts +5 -0
  126. package/lib/entries/fit/bootstrap/resolve-runtime-from-export-this.js +29 -0
  127. package/lib/entries/fit/bootstrap/top-level-runtime.d.ts +2 -0
  128. package/lib/entries/fit/bootstrap/top-level-runtime.js +9 -0
  129. package/lib/entries/fit/build-instance.d.ts +9 -0
  130. package/lib/entries/fit/build-instance.js +57 -0
  131. package/lib/entries/fit/exports/binding.d.ts +8 -0
  132. package/lib/entries/fit/exports/binding.js +15 -0
  133. package/lib/entries/fit/exports/device.d.ts +26 -0
  134. package/lib/entries/fit/exports/device.js +64 -0
  135. package/lib/entries/fit/exports/index.d.ts +3 -0
  136. package/lib/entries/fit/exports/index.js +3 -0
  137. package/lib/entries/fit/exports/temp.d.ts +19 -0
  138. package/lib/entries/fit/exports/temp.js +18 -0
  139. package/lib/entries/fit/index.d.ts +8 -0
  140. package/lib/entries/fit/index.js +36 -0
  141. package/lib/entries/main/bootstrap/bootstrap-lock-instance.d.ts +7 -0
  142. package/lib/entries/main/bootstrap/bootstrap-lock-instance.js +12 -0
  143. package/lib/entries/main/bootstrap/bootstrap.d.ts +4 -0
  144. package/lib/entries/main/bootstrap/bootstrap.js +69 -0
  145. package/lib/entries/main/bootstrap/lock-instance-runtime-ref.d.ts +3 -0
  146. package/lib/entries/main/bootstrap/lock-instance-runtime-ref.js +7 -0
  147. package/lib/entries/main/bootstrap/primary-instance.d.ts +6 -0
  148. package/lib/entries/main/bootstrap/primary-instance.js +24 -0
  149. package/lib/entries/main/bootstrap/resolve-runtime-from-export-this.d.ts +5 -0
  150. package/lib/entries/main/bootstrap/resolve-runtime-from-export-this.js +29 -0
  151. package/lib/entries/main/bootstrap/top-level-runtime.d.ts +2 -0
  152. package/lib/entries/main/bootstrap/top-level-runtime.js +9 -0
  153. package/lib/entries/main/build-instance.d.ts +7 -0
  154. package/lib/entries/main/build-instance.js +49 -0
  155. package/lib/entries/main/exports/accessory-binding.d.ts +1 -0
  156. package/lib/entries/main/exports/accessory-binding.js +1 -0
  157. package/lib/entries/main/exports/capability.d.ts +6 -0
  158. package/lib/entries/main/exports/capability.js +17 -0
  159. package/lib/entries/main/exports/config.d.ts +3 -0
  160. package/lib/entries/main/exports/config.js +5 -0
  161. package/lib/entries/main/exports/dp.d.ts +11 -0
  162. package/lib/entries/main/exports/dp.js +13 -0
  163. package/lib/entries/main/exports/fit.d.ts +8 -0
  164. package/lib/entries/main/exports/fit.js +14 -0
  165. package/lib/entries/main/exports/index.d.ts +20 -0
  166. package/lib/entries/main/exports/index.js +20 -0
  167. package/lib/entries/main/exports/linkage.d.ts +5 -0
  168. package/lib/entries/main/exports/linkage.js +15 -0
  169. package/lib/entries/main/exports/log.d.ts +10 -0
  170. package/lib/entries/main/exports/log.js +24 -0
  171. package/lib/entries/main/exports/media.d.ts +6 -0
  172. package/lib/entries/main/exports/media.js +18 -0
  173. package/lib/entries/main/exports/misc.d.ts +18 -0
  174. package/lib/entries/main/exports/misc.js +30 -0
  175. package/lib/entries/main/exports/offline-dps.d.ts +8 -0
  176. package/lib/entries/main/exports/offline-dps.js +28 -0
  177. package/lib/entries/main/exports/open/do-open-close-action.d.ts +2 -0
  178. package/lib/entries/main/exports/open/do-open-close-action.js +68 -0
  179. package/lib/entries/main/exports/open/index.d.ts +16 -0
  180. package/lib/entries/main/exports/open/index.js +44 -0
  181. package/lib/entries/main/exports/open.d.ts +16 -0
  182. package/lib/entries/main/exports/open.js +44 -0
  183. package/lib/entries/main/exports/screen/bind.d.ts +4 -0
  184. package/lib/entries/main/exports/screen/bind.js +8 -0
  185. package/lib/entries/main/exports/screen/list.d.ts +5 -0
  186. package/lib/entries/main/exports/screen/list.js +13 -0
  187. package/lib/entries/main/exports/signal.d.ts +6 -0
  188. package/lib/entries/main/exports/signal.js +14 -0
  189. package/lib/entries/main/exports/sleep.d.ts +15 -0
  190. package/lib/entries/main/exports/sleep.js +31 -0
  191. package/lib/entries/main/exports/state.d.ts +6 -0
  192. package/lib/entries/main/exports/state.js +19 -0
  193. package/lib/entries/main/exports/temporary.d.ts +32 -0
  194. package/lib/entries/main/exports/temporary.js +86 -0
  195. package/lib/entries/main/exports/unlock/sync.d.ts +1 -0
  196. package/lib/entries/main/exports/unlock/sync.js +5 -0
  197. package/lib/entries/main/exports/unlock-method.d.ts +19 -0
  198. package/lib/entries/main/exports/unlock-method.js +58 -0
  199. package/lib/entries/main/exports/user/index.d.ts +33 -0
  200. package/lib/entries/main/exports/user/index.js +35 -0
  201. package/lib/entries/main/exports/user/sync.d.ts +1 -0
  202. package/lib/entries/main/exports/user/sync.js +5 -0
  203. package/lib/entries/main/exports/voice-file.d.ts +7 -0
  204. package/lib/entries/main/exports/voice-file.js +17 -0
  205. package/lib/entries/main/exports/yu-channel.d.ts +5 -0
  206. package/lib/entries/main/exports/yu-channel.js +17 -0
  207. package/lib/entries/main/index.d.ts +8 -0
  208. package/lib/entries/main/index.js +36 -0
  209. package/lib/entries/screen/bootstrap/bootstrap-lock-instance.d.ts +7 -0
  210. package/lib/entries/screen/bootstrap/bootstrap-lock-instance.js +12 -0
  211. package/lib/entries/screen/bootstrap/bootstrap.d.ts +4 -0
  212. package/lib/entries/screen/bootstrap/bootstrap.js +69 -0
  213. package/lib/entries/screen/bootstrap/lock-instance-runtime-ref.d.ts +3 -0
  214. package/lib/entries/screen/bootstrap/lock-instance-runtime-ref.js +7 -0
  215. package/lib/entries/screen/bootstrap/primary-instance.d.ts +6 -0
  216. package/lib/entries/screen/bootstrap/primary-instance.js +24 -0
  217. package/lib/entries/screen/bootstrap/resolve-runtime-from-export-this.d.ts +5 -0
  218. package/lib/entries/screen/bootstrap/resolve-runtime-from-export-this.js +29 -0
  219. package/lib/entries/screen/bootstrap/top-level-runtime.d.ts +2 -0
  220. package/lib/entries/screen/bootstrap/top-level-runtime.js +9 -0
  221. package/lib/entries/screen/build-instance.d.ts +9 -0
  222. package/lib/entries/screen/build-instance.js +57 -0
  223. package/lib/entries/screen/exports/binding.d.ts +6 -0
  224. package/lib/entries/screen/exports/binding.js +15 -0
  225. package/lib/entries/screen/exports/device.d.ts +16 -0
  226. package/lib/entries/screen/exports/device.js +41 -0
  227. package/lib/entries/screen/exports/event.d.ts +3 -0
  228. package/lib/entries/screen/exports/event.js +5 -0
  229. package/lib/entries/screen/exports/index.d.ts +4 -0
  230. package/lib/entries/screen/exports/index.js +4 -0
  231. package/lib/entries/screen/exports/user.d.ts +2 -0
  232. package/lib/entries/screen/exports/user.js +8 -0
  233. package/lib/entries/screen/index.d.ts +8 -0
  234. package/lib/entries/screen/index.js +36 -0
  235. package/lib/feature/dp/get-dp-value.d.ts +3 -0
  236. package/lib/feature/dp/get-dp-value.js +3 -0
  237. package/lib/feature/dp/has-dp.d.ts +2 -0
  238. package/lib/feature/dp/has-dp.js +1 -0
  239. package/lib/feature/dp/publish-dps.d.ts +7 -0
  240. package/lib/feature/dp/publish-dps.js +155 -0
  241. package/lib/feature/fit/bind-fit-to-lock.d.ts +6 -0
  242. package/lib/feature/fit/bind-fit-to-lock.js +222 -0
  243. package/lib/feature/fit/bind-lock-to-fit.d.ts +4 -0
  244. package/lib/feature/fit/bind-lock-to-fit.js +167 -0
  245. package/lib/feature/fit/ble-key.d.ts +16 -0
  246. package/lib/feature/fit/ble-key.js +99 -0
  247. package/lib/feature/fit/list.d.ts +3 -0
  248. package/lib/feature/fit/list.js +28 -0
  249. package/lib/feature/fit/method/add-flow.d.ts +7 -0
  250. package/lib/feature/fit/method/add-flow.js +380 -0
  251. package/lib/feature/fit/method/add-method-events.d.ts +5 -0
  252. package/lib/feature/fit/method/add-method-events.js +11 -0
  253. package/lib/feature/fit/method/add-password.d.ts +3 -0
  254. package/lib/feature/fit/method/add-password.js +99 -0
  255. package/lib/feature/fit/method/internal/base.d.ts +19 -0
  256. package/lib/feature/fit/method/internal/base.js +134 -0
  257. package/lib/feature/fit/method/list.d.ts +3 -0
  258. package/lib/feature/fit/method/list.js +64 -0
  259. package/lib/feature/fit/method/types.d.ts +68 -0
  260. package/lib/feature/fit/method/types.js +1 -0
  261. package/lib/feature/fit/method/update-remove.d.ts +4 -0
  262. package/lib/feature/fit/method/update-remove.js +159 -0
  263. package/lib/feature/fit/password-list.d.ts +24 -0
  264. package/lib/feature/fit/password-list.js +31 -0
  265. package/lib/feature/fit/resolve-slave-id.d.ts +2 -0
  266. package/lib/feature/fit/resolve-slave-id.js +38 -0
  267. package/lib/feature/fit/setting.d.ts +2 -0
  268. package/lib/feature/fit/setting.js +27 -0
  269. package/lib/feature/fit/shared.d.ts +27 -0
  270. package/lib/feature/fit/shared.js +118 -0
  271. package/lib/feature/fit/sync.d.ts +4 -0
  272. package/lib/feature/fit/sync.js +85 -0
  273. package/lib/feature/fit/temp-password.d.ts +27 -0
  274. package/lib/feature/fit/temp-password.js +428 -0
  275. package/lib/feature/fit/users.d.ts +12 -0
  276. package/lib/feature/fit/users.js +25 -0
  277. package/lib/feature/linkage/linkage.d.ts +10 -0
  278. package/lib/{linkage.js → feature/linkage/linkage.js} +30 -30
  279. package/lib/feature/log/log.d.ts +63 -0
  280. package/lib/feature/log/log.js +438 -0
  281. package/lib/feature/media/media.d.ts +31 -0
  282. package/lib/feature/media/media.js +66 -0
  283. package/lib/feature/media/rotate.d.ts +6 -0
  284. package/lib/feature/media/rotate.js +6 -0
  285. package/lib/feature/misc/ble-control.d.ts +2 -0
  286. package/lib/feature/misc/ble-control.js +38 -0
  287. package/lib/feature/misc/capability.d.ts +8 -0
  288. package/lib/{capability.js → feature/misc/capability.js} +39 -29
  289. package/lib/feature/misc/connect-device.d.ts +2 -0
  290. package/lib/feature/misc/connect-device.js +206 -0
  291. package/lib/feature/misc/dp-period.d.ts +18 -0
  292. package/lib/feature/misc/dp-period.js +75 -0
  293. package/lib/feature/misc/is-use-near-channel-for-runtime.d.ts +2 -0
  294. package/lib/feature/misc/is-use-near-channel-for-runtime.js +17 -0
  295. package/lib/feature/misc/open-scene.d.ts +3 -0
  296. package/lib/feature/misc/open-scene.js +63 -0
  297. package/lib/feature/misc/signal.d.ts +12 -0
  298. package/lib/feature/misc/signal.js +36 -0
  299. package/lib/feature/misc/sleep.d.ts +14 -0
  300. package/lib/feature/misc/sleep.js +66 -0
  301. package/lib/feature/misc/types.d.ts +7 -0
  302. package/lib/feature/misc/types.js +1 -0
  303. package/lib/feature/misc/update-config.d.ts +4 -0
  304. package/lib/feature/misc/update-config.js +9 -0
  305. package/lib/feature/misc/validate-pwd.d.ts +2 -0
  306. package/lib/feature/misc/validate-pwd.js +10 -0
  307. package/lib/feature/misc/yu-channel.d.ts +6 -0
  308. package/lib/feature/misc/yu-channel.js +26 -0
  309. package/lib/feature/offline-dps/index.d.ts +10 -0
  310. package/lib/feature/offline-dps/index.js +133 -0
  311. package/lib/feature/password/ble-temp-payload.d.ts +3 -0
  312. package/lib/{sync → feature/password}/ble-temp-payload.js +10 -10
  313. package/lib/feature/password/sync-temp.d.ts +4 -0
  314. package/lib/feature/password/sync-temp.js +91 -0
  315. package/lib/feature/password/temporary/custom-dp-ble.d.ts +6 -0
  316. package/lib/feature/password/temporary/custom-dp-ble.js +263 -0
  317. package/lib/feature/password/temporary/custom-dp-create-shared.d.ts +34 -0
  318. package/lib/feature/password/temporary/custom-dp-create-shared.js +64 -0
  319. package/lib/feature/password/temporary/custom-dp.d.ts +6 -0
  320. package/lib/feature/password/temporary/custom-dp.js +241 -0
  321. package/lib/feature/password/temporary/freeze-ble-key.d.ts +4 -0
  322. package/lib/feature/password/temporary/freeze-ble-key.js +7 -0
  323. package/lib/feature/password/temporary/freeze-rename.d.ts +5 -0
  324. package/lib/feature/password/temporary/freeze-rename.js +72 -0
  325. package/lib/feature/password/temporary/internal/change-password-phase.d.ts +2 -0
  326. package/lib/feature/password/temporary/internal/change-password-phase.js +48 -0
  327. package/lib/feature/password/temporary/internal/constants.d.ts +12 -0
  328. package/lib/feature/password/temporary/internal/constants.js +21 -0
  329. package/lib/feature/password/temporary/internal/password-helpers.d.ts +4 -0
  330. package/lib/feature/password/temporary/internal/password-helpers.js +18 -0
  331. package/lib/feature/password/temporary/internal/password-type-map.d.ts +2 -0
  332. package/lib/feature/password/temporary/internal/password-type-map.js +7 -0
  333. package/lib/feature/password/temporary/lists.d.ts +16 -0
  334. package/lib/feature/password/temporary/lists.js +157 -0
  335. package/lib/feature/password/temporary/offline-create.d.ts +7 -0
  336. package/lib/feature/password/temporary/offline-create.js +192 -0
  337. package/lib/feature/password/temporary/types.d.ts +107 -0
  338. package/lib/feature/password/temporary/types.js +1 -0
  339. package/lib/feature/password/temporary/wifi-offline.d.ts +5 -0
  340. package/lib/feature/password/temporary/wifi-offline.js +85 -0
  341. package/lib/feature/password/temporary/wifi-online.d.ts +28 -0
  342. package/lib/feature/password/temporary/wifi-online.js +153 -0
  343. package/lib/feature/screen/bind.d.ts +4 -0
  344. package/lib/feature/screen/bind.js +181 -0
  345. package/lib/feature/screen/error.d.ts +1 -0
  346. package/lib/feature/screen/error.js +34 -0
  347. package/lib/feature/screen/event.d.ts +3 -0
  348. package/lib/feature/screen/event.js +19 -0
  349. package/lib/feature/screen/list.d.ts +13 -0
  350. package/lib/feature/screen/list.js +56 -0
  351. package/lib/feature/service/goto-service.d.ts +5 -0
  352. package/lib/feature/service/goto-service.js +16 -0
  353. package/lib/feature/state/clear.d.ts +2 -0
  354. package/lib/feature/state/clear.js +17 -0
  355. package/lib/feature/state/device-status-events.d.ts +5 -0
  356. package/lib/feature/state/device-status-events.js +11 -0
  357. package/lib/feature/state/device-status.d.ts +5 -0
  358. package/lib/feature/state/device-status.js +130 -0
  359. package/lib/feature/state/dp-change.d.ts +3 -0
  360. package/lib/feature/state/dp-change.js +44 -0
  361. package/lib/feature/state/init-state.d.ts +2 -0
  362. package/lib/feature/state/init-state.js +167 -0
  363. package/lib/feature/state/internal/read-is-sleep.d.ts +2 -0
  364. package/lib/feature/state/internal/read-is-sleep.js +9 -0
  365. package/lib/feature/state/internal/share-thread-local.d.ts +2 -0
  366. package/lib/feature/state/internal/share-thread-local.js +4 -0
  367. package/lib/feature/state/platform-routing.d.ts +3 -0
  368. package/lib/feature/state/platform-routing.js +155 -0
  369. package/lib/feature/state/remote-permissions.d.ts +4 -0
  370. package/lib/feature/state/remote-permissions.js +30 -0
  371. package/lib/feature/state/sync/offline-dps.d.ts +2 -0
  372. package/lib/feature/state/sync/offline-dps.js +71 -0
  373. package/lib/feature/state/sync/remote-serect-key.d.ts +3 -0
  374. package/lib/feature/state/sync/remote-serect-key.js +74 -0
  375. package/lib/feature/state/sync/t0.d.ts +3 -0
  376. package/lib/feature/state/sync/t0.js +64 -0
  377. package/lib/feature/unlock/door/check-remote.d.ts +2 -0
  378. package/lib/feature/unlock/door/check-remote.js +40 -0
  379. package/lib/feature/unlock/door/check-user-valid.d.ts +2 -0
  380. package/lib/feature/unlock/door/check-user-valid.js +21 -0
  381. package/lib/feature/unlock/door/door-action.d.ts +2 -0
  382. package/lib/feature/unlock/door/door-action.js +32 -0
  383. package/lib/feature/unlock/door/door-ble-only.d.ts +2 -0
  384. package/lib/feature/unlock/door/door-ble-only.js +102 -0
  385. package/lib/feature/unlock/door/door-matter-lan.d.ts +2 -0
  386. package/lib/feature/unlock/door/door-matter-lan.js +15 -0
  387. package/lib/feature/unlock/door/door-near-dual-mode.d.ts +2 -0
  388. package/lib/feature/unlock/door/door-near-dual-mode.js +39 -0
  389. package/lib/feature/unlock/door/door-remote-cloud.d.ts +2 -0
  390. package/lib/feature/unlock/door/door-remote-cloud.js +69 -0
  391. package/lib/feature/unlock/door/door-report.d.ts +11 -0
  392. package/lib/feature/unlock/door/door-report.js +96 -0
  393. package/lib/feature/unlock/door/internal/report-error.d.ts +2 -0
  394. package/lib/feature/unlock/door/internal/report-error.js +46 -0
  395. package/lib/feature/unlock/door/open-close-path.d.ts +3 -0
  396. package/lib/feature/unlock/door/open-close-path.js +30 -0
  397. package/lib/feature/unlock/door/remote-permission.d.ts +5 -0
  398. package/lib/feature/unlock/door/remote-permission.js +67 -0
  399. package/lib/feature/unlock/door/remove-share-user-once.d.ts +2 -0
  400. package/lib/feature/unlock/door/remove-share-user-once.js +21 -0
  401. package/lib/feature/unlock/door/types.d.ts +4 -0
  402. package/lib/feature/unlock/door/types.js +1 -0
  403. package/lib/feature/unlock/door/voice-unlock-pwd.d.ts +4 -0
  404. package/lib/feature/unlock/door/voice-unlock-pwd.js +25 -0
  405. package/lib/feature/unlock/door/wifi-pro-confirm.d.ts +2 -0
  406. package/lib/feature/unlock/door/wifi-pro-confirm.js +69 -0
  407. package/lib/feature/unlock/method/add-flow.d.ts +7 -0
  408. package/lib/feature/unlock/method/add-flow.js +403 -0
  409. package/lib/feature/unlock/method/add-method-events.d.ts +5 -0
  410. package/lib/feature/unlock/method/add-method-events.js +11 -0
  411. package/lib/feature/unlock/method/add-password.d.ts +3 -0
  412. package/lib/feature/unlock/method/add-password.js +99 -0
  413. package/lib/feature/unlock/method/bind-unbind.d.ts +8 -0
  414. package/lib/feature/unlock/method/bind-unbind.js +113 -0
  415. package/lib/feature/unlock/method/detail.d.ts +3 -0
  416. package/lib/feature/unlock/method/detail.js +35 -0
  417. package/lib/feature/unlock/method/guide.d.ts +3 -0
  418. package/lib/feature/unlock/method/guide.js +48 -0
  419. package/lib/feature/unlock/method/internal/base.d.ts +109 -0
  420. package/lib/feature/unlock/method/internal/base.js +89 -0
  421. package/lib/feature/unlock/method/internal/errors.d.ts +5 -0
  422. package/lib/feature/unlock/method/internal/errors.js +13 -0
  423. package/lib/feature/unlock/method/internal/special-check.d.ts +13 -0
  424. package/lib/feature/unlock/method/internal/special-check.js +38 -0
  425. package/lib/feature/unlock/method/types.d.ts +70 -0
  426. package/lib/feature/unlock/method/types.js +1 -0
  427. package/lib/feature/unlock/method/update-remove.d.ts +4 -0
  428. package/lib/feature/unlock/method/update-remove.js +138 -0
  429. package/lib/feature/unlock/method/verify-code.d.ts +3 -0
  430. package/lib/feature/unlock/method/verify-code.js +7 -0
  431. package/lib/feature/unlock/sync/unlock-method.d.ts +3 -0
  432. package/lib/feature/unlock/sync/unlock-method.js +79 -0
  433. package/lib/feature/user/current-user.d.ts +3 -0
  434. package/lib/feature/user/current-user.js +33 -0
  435. package/lib/feature/user/delete-user-dp.d.ts +3 -0
  436. package/lib/{utils/user.js → feature/user/delete-user-dp.js} +13 -13
  437. package/lib/feature/user/share-user.d.ts +29 -0
  438. package/lib/feature/user/share-user.js +228 -0
  439. package/lib/feature/user/sync-user.d.ts +2 -0
  440. package/lib/feature/user/sync-user.js +151 -0
  441. package/lib/feature/user/user.d.ts +37 -0
  442. package/lib/feature/user/user.js +484 -0
  443. package/lib/feature/utils/index.d.ts +12 -0
  444. package/lib/feature/utils/index.js +165 -0
  445. package/lib/feature/voice-file/voice-file.d.ts +27 -0
  446. package/lib/feature/voice-file/voice-file.js +203 -0
  447. package/lib/fit.d.ts +4 -0
  448. package/lib/fit.js +3 -0
  449. package/lib/index.d.ts +2 -21
  450. package/lib/index.js +1 -74
  451. package/lib/interface.d.ts +50 -3
  452. package/lib/{utils → platform}/device.d.ts +48 -0
  453. package/lib/{utils → platform}/device.js +153 -2
  454. package/lib/platform/index.d.ts +2 -0
  455. package/lib/platform/index.js +2 -0
  456. package/lib/{utils → platform}/ipc.d.ts +3 -0
  457. package/lib/{utils → platform}/ipc.js +11 -0
  458. package/lib/platform/transport/index.d.ts +1 -0
  459. package/lib/platform/transport/index.js +1 -0
  460. package/lib/runtime/LockDeviceRuntime.d.ts +12 -0
  461. package/lib/runtime/LockDeviceRuntime.js +34 -0
  462. package/lib/runtime/device-status/compute-device-status.d.ts +25 -0
  463. package/lib/runtime/device-status/compute-device-status.js +94 -0
  464. package/lib/runtime/index.d.ts +5 -0
  465. package/lib/runtime/index.js +3 -0
  466. package/lib/runtime/lock-config.d.ts +28 -0
  467. package/lib/runtime/lock-config.js +37 -0
  468. package/lib/runtime/registry.d.ts +7 -0
  469. package/lib/runtime/registry.js +28 -0
  470. package/lib/runtime/runtime-state-types.d.ts +20 -0
  471. package/lib/runtime/runtime-state-types.js +1 -0
  472. package/lib/screen.d.ts +4 -0
  473. package/lib/screen.js +3 -0
  474. package/lib/utils/constant.d.ts +3 -0
  475. package/lib/utils/constant.js +3 -0
  476. package/lib/utils/errors.js +39 -4
  477. package/lib/utils/event.js +2 -1
  478. package/lib/utils/index.d.ts +22 -13
  479. package/lib/utils/index.js +39 -118
  480. package/lib/utils/sdk-log.d.ts +28 -0
  481. package/lib/utils/sdk-log.js +128 -0
  482. package/package.json +26 -7
  483. package/lib/capability.d.ts +0 -4
  484. package/lib/config/index.d.ts +0 -28
  485. package/lib/config/index.js +0 -41
  486. package/lib/event.d.ts +0 -2
  487. package/lib/event.js +0 -2
  488. package/lib/linkage.d.ts +0 -8
  489. package/lib/log.d.ts +0 -41
  490. package/lib/log.js +0 -311
  491. package/lib/media.d.ts +0 -14
  492. package/lib/media.js +0 -27
  493. package/lib/offline-dps.d.ts +0 -9
  494. package/lib/offline-dps.js +0 -76
  495. package/lib/open/ble-dedicated-dp.d.ts +0 -4
  496. package/lib/open/ble-dedicated-dp.js +0 -148
  497. package/lib/open/ble-remote-no-dp-key.d.ts +0 -4
  498. package/lib/open/ble-remote-no-dp-key.js +0 -69
  499. package/lib/open/report-status.d.ts +0 -1
  500. package/lib/open/report-status.js +0 -23
  501. package/lib/open.d.ts +0 -22
  502. package/lib/open.js +0 -262
  503. package/lib/other.d.ts +0 -31
  504. package/lib/other.js +0 -291
  505. package/lib/signal.d.ts +0 -14
  506. package/lib/signal.js +0 -31
  507. package/lib/sleep.d.ts +0 -19
  508. package/lib/sleep.js +0 -79
  509. package/lib/state.d.ts +0 -16
  510. package/lib/state.js +0 -351
  511. package/lib/sync/ble-temp-payload.d.ts +0 -2
  512. package/lib/sync/offline-dps.d.ts +0 -1
  513. package/lib/sync/offline-dps.js +0 -29
  514. package/lib/sync/remote-serect-key.d.ts +0 -2
  515. package/lib/sync/remote-serect-key.js +0 -43
  516. package/lib/sync/t0.d.ts +0 -2
  517. package/lib/sync/t0.js +0 -26
  518. package/lib/sync/temp.d.ts +0 -3
  519. package/lib/sync/temp.js +0 -70
  520. package/lib/sync/unlock-method.d.ts +0 -2
  521. package/lib/sync/unlock-method.js +0 -42
  522. package/lib/sync/user.d.ts +0 -2
  523. package/lib/sync/user.js +0 -68
  524. package/lib/temporary.d.ts +0 -171
  525. package/lib/temporary.js +0 -698
  526. package/lib/unlock-method.d.ts +0 -90
  527. package/lib/unlock-method.js +0 -701
  528. package/lib/user.d.ts +0 -30
  529. package/lib/user.js +0 -298
  530. package/lib/utils/publishDps.d.ts +0 -6
  531. package/lib/utils/publishDps.js +0 -78
  532. package/lib/utils/user.d.ts +0 -2
  533. /package/lib/{parse/index.d.ts → utils/parse.d.ts} +0 -0
  534. /package/lib/{parse/index.js → utils/parse.js} +0 -0
@@ -0,0 +1,99 @@
1
+ import { getFitBleKeyListApi, addFitBleKeyApi, updateFitBleKeyApi, removeFitBleKeyApi, renameFitBleKeyApi, } from "../../api/fit";
2
+ import { sdkLog } from "../../utils/sdk-log";
3
+ import { formatWeek } from "../../utils";
4
+ export async function getFitBleKeyListForRuntime(runtime) {
5
+ const startedAt = Date.now();
6
+ sdkLog("info", "fit", "getBleKeyListStart", {
7
+ devId: runtime.devId,
8
+ });
9
+ const list = await getFitBleKeyListApi(runtime.devId);
10
+ sdkLog("info", "fit", "getBleKeyListSuccess", {
11
+ devId: runtime.devId,
12
+ duration: Date.now() - startedAt,
13
+ data: { count: Array.isArray(list) ? list.length : 0 },
14
+ });
15
+ return list;
16
+ }
17
+ export async function addFitBleKeyForRuntime(runtime, params) {
18
+ const startedAt = Date.now();
19
+ const logParams = params ?? {};
20
+ sdkLog("info", "fit", "addBleKeyStart", {
21
+ devId: runtime.devId,
22
+ data: {
23
+ hasName: typeof logParams["name"] === "string",
24
+ hasLockDevId: typeof logParams["lockDevId"] === "string",
25
+ },
26
+ });
27
+ const result = await addFitBleKeyApi(runtime.devId, params);
28
+ sdkLog("info", "fit", "addBleKeySuccess", {
29
+ devId: runtime.devId,
30
+ duration: Date.now() - startedAt,
31
+ });
32
+ return result;
33
+ }
34
+ export async function updateFitBleKeyForRuntime(runtime, params) {
35
+ const startedAt = Date.now();
36
+ const logParams = params ?? {};
37
+ sdkLog("info", "fit", "updateBleKeyStart", {
38
+ devId: runtime.devId,
39
+ data: {
40
+ hasName: typeof logParams["name"] === "string",
41
+ hasId: typeof logParams["id"] === "string",
42
+ },
43
+ });
44
+ const schedule = [
45
+ {
46
+ allDay: params.effective.repeat !== "week",
47
+ effectiveTime: params.effective.effectiveTime ?? 0,
48
+ invalidTime: params.effective.expiredTime ?? 0,
49
+ workingDay: formatWeek(params.effective.weeks ?? [0]),
50
+ },
51
+ ];
52
+ const result = await updateFitBleKeyApi(runtime.devId, {
53
+ unlockBindingId: params.id,
54
+ name: params.name,
55
+ effectiveTime: params.effective.effectiveDate,
56
+ invalidTime: params.effective.expiredDate,
57
+ schedule,
58
+ timeSetType: params.effective.repeat !== "week" ? 20 : 30,
59
+ });
60
+ sdkLog("info", "fit", "updateBleKeySuccess", {
61
+ devId: runtime.devId,
62
+ duration: Date.now() - startedAt,
63
+ });
64
+ return result;
65
+ }
66
+ export async function removeFitBleKeyForRuntime(runtime, unlockBindingId) {
67
+ const startedAt = Date.now();
68
+ sdkLog("info", "fit", "removeBleKeyStart", {
69
+ devId: runtime.devId,
70
+ data: { unlockBindingId },
71
+ });
72
+ const result = await removeFitBleKeyApi(runtime.devId, unlockBindingId);
73
+ sdkLog("info", "fit", "removeBleKeySuccess", {
74
+ devId: runtime.devId,
75
+ duration: Date.now() - startedAt,
76
+ data: { unlockBindingId },
77
+ });
78
+ return result;
79
+ }
80
+ export async function renameFitBleKeyForRuntime(runtime, params) {
81
+ const startedAt = Date.now();
82
+ const logParams = params ?? {};
83
+ sdkLog("info", "fit", "renameBleKeyStart", {
84
+ devId: runtime.devId,
85
+ data: {
86
+ hasName: typeof logParams["name"] === "string",
87
+ hasUnlockBindingId: typeof logParams["id"] === "string",
88
+ },
89
+ });
90
+ const result = await renameFitBleKeyApi(runtime.devId, {
91
+ unlockBindingId: params.id,
92
+ name: params.name,
93
+ });
94
+ sdkLog("info", "fit", "renameBleKeySuccess", {
95
+ devId: runtime.devId,
96
+ duration: Date.now() - startedAt,
97
+ });
98
+ return result;
99
+ }
@@ -0,0 +1,3 @@
1
+ import type { LockDeviceRuntime } from "../../runtime/LockDeviceRuntime";
2
+ export declare function getBoundLockListForRuntime(runtime: LockDeviceRuntime): Promise<import("../../api/fit").BoundFitLockItem[]>;
3
+ export declare function getUnbindLockListForRuntime(runtime: LockDeviceRuntime): Promise<import("../../api/fit").UnbindLockItem[]>;
@@ -0,0 +1,28 @@
1
+ import { getBoundLockListApi, getUnbindLockListApi, } from "../../api/fit";
2
+ import { sdkLog } from "../../utils/sdk-log";
3
+ export async function getBoundLockListForRuntime(runtime) {
4
+ const startedAt = Date.now();
5
+ sdkLog("info", "fit", "getBoundLockListStart", {
6
+ devId: runtime.devId,
7
+ });
8
+ const list = await getBoundLockListApi(runtime.devId);
9
+ sdkLog("info", "fit", "getBoundLockListSuccess", {
10
+ devId: runtime.devId,
11
+ duration: Date.now() - startedAt,
12
+ data: { count: Array.isArray(list) ? list.length : 0 },
13
+ });
14
+ return list;
15
+ }
16
+ export async function getUnbindLockListForRuntime(runtime) {
17
+ const startedAt = Date.now();
18
+ sdkLog("info", "fit", "getUnbindLockListStart", {
19
+ devId: runtime.devId,
20
+ });
21
+ const list = await getUnbindLockListApi(runtime.devId);
22
+ sdkLog("info", "fit", "getUnbindLockListSuccess", {
23
+ devId: runtime.devId,
24
+ duration: Date.now() - startedAt,
25
+ data: { count: Array.isArray(list) ? list.length : 0 },
26
+ });
27
+ return list;
28
+ }
@@ -0,0 +1,7 @@
1
+ import type { LockDeviceRuntime } from "../../../runtime/LockDeviceRuntime";
2
+ import type { FitCancelAddUnlockMethodParams, FitStartAddUnlockMethodParams } from "./types";
3
+ export interface FitStartAddUnlockMethodResult {
4
+ total: number;
5
+ }
6
+ export declare function fitStartAddUnlockMethodForRuntime(rt: LockDeviceRuntime, params: FitStartAddUnlockMethodParams): Promise<FitStartAddUnlockMethodResult>;
7
+ export declare const fitCancelAddUnlockMethodForRuntime: (this: unknown, rt: LockDeviceRuntime, params: FitCancelAddUnlockMethodParams) => Promise<void>;
@@ -0,0 +1,380 @@
1
+ import dpUtils from "@ray-js/tuya-dp-transform";
2
+ import { addFitOpenMode } from "../../../api/fit";
3
+ import { sleep } from "../../../utils";
4
+ import { DPCHANGE } from "../../../utils/constant";
5
+ import { getError } from "../../../utils/errors";
6
+ import emitter from "../../../utils/event";
7
+ import { publishDpsForRuntime } from "../../dp/publish-dps";
8
+ import { parallelOnlyForRuntime } from "../../utils";
9
+ import { getUnlockMethodTypeByTypeForRuntime } from "../../utils";
10
+ import { getUserInfoOnDevForRuntime } from "../../user/user";
11
+ import { getAddUnlockError } from "../../unlock/method/internal/errors";
12
+ import { sdkLog } from "../../../utils/sdk-log";
13
+ import { getFitUnlockMethodBase } from "./internal/base";
14
+ import { getFitUnlockMethodEvent } from "./add-method-events";
15
+ const addUnlockMethodData = {
16
+ runtime: null,
17
+ unlockMethodConfig: {},
18
+ total: 0,
19
+ dpCode: "",
20
+ dpMap: {},
21
+ slaveId: 0,
22
+ lockDevId: "",
23
+ lockUserId: 0,
24
+ userId: "",
25
+ unlockDpId: 0,
26
+ timeout: 15000,
27
+ timeoutId: 0,
28
+ };
29
+ let isCancelAddUnlockMethod = false;
30
+ const handleAddTimeout = (timeout = 15000) => {
31
+ clearTimeout(addUnlockMethodData.timeoutId);
32
+ addUnlockMethodData.timeoutId = setTimeout(() => {
33
+ emitter.off(DPCHANGE, handleAddReport);
34
+ const rt = addUnlockMethodData.runtime;
35
+ if (!rt)
36
+ return;
37
+ sdkLog("warn", "fitUnlockMethod", "addMethodTimeout", {
38
+ devId: rt.devId,
39
+ data: {
40
+ type: addUnlockMethodData.unlockMethodConfig.type,
41
+ lockDevId: addUnlockMethodData.lockDevId,
42
+ },
43
+ error: getError(1002),
44
+ });
45
+ emitter.emit(getFitUnlockMethodEvent(rt), {
46
+ type: addUnlockMethodData.unlockMethodConfig.type,
47
+ stage: "fail",
48
+ lockDevId: addUnlockMethodData.lockDevId,
49
+ lockUserId: addUnlockMethodData.lockUserId,
50
+ error: getError(1002),
51
+ });
52
+ }, timeout);
53
+ };
54
+ const clearMonitoringAddReport = () => {
55
+ clearTimeout(addUnlockMethodData.timeoutId);
56
+ emitter.off(DPCHANGE, handleAddReport);
57
+ addUnlockMethodData.runtime = null;
58
+ };
59
+ const handleAddReport = async (dps) => {
60
+ const rt = addUnlockMethodData.runtime;
61
+ if (!rt) {
62
+ return;
63
+ }
64
+ const cfg = rt.config;
65
+ if (!dps[addUnlockMethodData.dpCode]) {
66
+ return;
67
+ }
68
+ const result = dpUtils.parse(dps[addUnlockMethodData.dpCode], addUnlockMethodData.dpMap);
69
+ if (result.type !== addUnlockMethodData.unlockMethodConfig.id) {
70
+ return;
71
+ }
72
+ if (result.slaveId !== addUnlockMethodData.slaveId) {
73
+ return;
74
+ }
75
+ if (cfg.strictMode) {
76
+ if (result.memberId !== addUnlockMethodData.lockUserId) {
77
+ return;
78
+ }
79
+ }
80
+ else if (result.memberId !== addUnlockMethodData.lockUserId) {
81
+ console.warn(`FitAddUnlockMethod: lockUserId mismatch, expected ${addUnlockMethodData.lockUserId}, got ${result.memberId}`);
82
+ }
83
+ const type = addUnlockMethodData.unlockMethodConfig.type;
84
+ let eventData = null;
85
+ switch (result.stage) {
86
+ case 0xfc: {
87
+ handleAddTimeout(addUnlockMethodData.timeout);
88
+ sdkLog("info", "fitUnlockMethod", "addMethodStep", {
89
+ devId: rt.devId,
90
+ data: {
91
+ type,
92
+ lockDevId: addUnlockMethodData.lockDevId,
93
+ step: result.step,
94
+ total: addUnlockMethodData.total,
95
+ },
96
+ });
97
+ eventData = {
98
+ type,
99
+ stage: "step",
100
+ lockDevId: addUnlockMethodData.lockDevId,
101
+ lockUserId: result.memberId,
102
+ step: result.step,
103
+ total: addUnlockMethodData.total,
104
+ };
105
+ break;
106
+ }
107
+ case 0xfd: {
108
+ clearMonitoringAddReport();
109
+ sdkLog("warn", "fitUnlockMethod", "addMethodDpFail", {
110
+ devId: rt.devId,
111
+ data: {
112
+ type,
113
+ lockDevId: addUnlockMethodData.lockDevId,
114
+ status: result.status,
115
+ },
116
+ error: getAddUnlockError(result.status),
117
+ });
118
+ eventData = {
119
+ stage: "fail",
120
+ type,
121
+ lockDevId: addUnlockMethodData.lockDevId,
122
+ lockUserId: result.memberId,
123
+ error: getAddUnlockError(result.status),
124
+ };
125
+ break;
126
+ }
127
+ case 0xfe: {
128
+ clearMonitoringAddReport();
129
+ if (isCancelAddUnlockMethod) {
130
+ isCancelAddUnlockMethod = false;
131
+ sdkLog("info", "fitUnlockMethod", "addMethodCancelAck", {
132
+ devId: rt.devId,
133
+ data: { type, lockDevId: addUnlockMethodData.lockDevId },
134
+ });
135
+ return;
136
+ }
137
+ sdkLog("warn", "fitUnlockMethod", "addMethodCancelStageFail", {
138
+ devId: rt.devId,
139
+ data: {
140
+ type,
141
+ lockDevId: addUnlockMethodData.lockDevId,
142
+ status: result.status,
143
+ },
144
+ error: getAddUnlockError(result.status),
145
+ });
146
+ eventData = {
147
+ stage: "fail",
148
+ type,
149
+ lockDevId: addUnlockMethodData.lockDevId,
150
+ lockUserId: result.memberId,
151
+ error: getAddUnlockError(result.status),
152
+ };
153
+ break;
154
+ }
155
+ case 0xff: {
156
+ clearMonitoringAddReport();
157
+ try {
158
+ await sleep(300);
159
+ let isAddEnabled = true;
160
+ if (!cfg.supportMultipleFace && type === "face") {
161
+ const user = await getUserInfoOnDevForRuntime(rt, {
162
+ devId: addUnlockMethodData.lockDevId,
163
+ userId: addUnlockMethodData.userId,
164
+ });
165
+ const faceData = user.unlockDetails.find((item) => item.type === "face" && item.unlockList.length > 0);
166
+ if (faceData) {
167
+ const originUnlockId = faceData.unlockList[0].unlockId;
168
+ if (originUnlockId !== result.unlockId) {
169
+ eventData = {
170
+ stage: "fail",
171
+ type,
172
+ lockDevId: addUnlockMethodData.lockDevId,
173
+ lockUserId: result.memberId,
174
+ error: getError(1061),
175
+ };
176
+ sdkLog("warn", "fitUnlockMethod", "addMethodDuplicateFace", {
177
+ devId: rt.devId,
178
+ data: { lockDevId: addUnlockMethodData.lockDevId },
179
+ error: getError(1061),
180
+ });
181
+ }
182
+ else {
183
+ eventData = {
184
+ stage: "success",
185
+ type,
186
+ lockDevId: addUnlockMethodData.lockDevId,
187
+ id: faceData.unlockList[0].id,
188
+ name: faceData.unlockList[0].unlockName,
189
+ };
190
+ }
191
+ isAddEnabled = false;
192
+ }
193
+ }
194
+ if (isAddEnabled) {
195
+ await addFitOpenMode({
196
+ devIdList: [addUnlockMethodData.lockDevId],
197
+ fittingId: rt.devId,
198
+ unlockId: `${addUnlockMethodData.unlockDpId}-${result.unlockId}`,
199
+ unlockName: "",
200
+ userId: addUnlockMethodData.userId,
201
+ hijack: false,
202
+ });
203
+ eventData = {
204
+ stage: "success",
205
+ type,
206
+ lockDevId: addUnlockMethodData.lockDevId,
207
+ id: 0,
208
+ name: "",
209
+ };
210
+ sdkLog("info", "fitUnlockMethod", "addMethodSuccess", {
211
+ devId: rt.devId,
212
+ data: { type, lockDevId: addUnlockMethodData.lockDevId },
213
+ });
214
+ }
215
+ }
216
+ catch (err) {
217
+ console.warn("FitAddUnlockMethod failed", err);
218
+ sdkLog("error", "fitUnlockMethod", "addMethodCloudFail", {
219
+ devId: rt.devId,
220
+ data: { type, lockDevId: addUnlockMethodData.lockDevId },
221
+ error: err,
222
+ });
223
+ eventData = {
224
+ stage: "fail",
225
+ type,
226
+ lockDevId: addUnlockMethodData.lockDevId,
227
+ lockUserId: result.memberId,
228
+ error: getError(1053),
229
+ };
230
+ }
231
+ break;
232
+ }
233
+ default:
234
+ }
235
+ if (eventData) {
236
+ const eventKey = getFitUnlockMethodEvent(rt);
237
+ if (emitter.hasListener(eventKey)) {
238
+ emitter.emit(eventKey, eventData);
239
+ }
240
+ else {
241
+ emitter.cache(eventKey, eventData);
242
+ }
243
+ }
244
+ };
245
+ const monitoringAddReport = (option) => {
246
+ Object.assign(addUnlockMethodData, {
247
+ timeout: 15000,
248
+ ...option,
249
+ });
250
+ emitter.clearCache(getFitUnlockMethodEvent(option.runtime));
251
+ emitter.off(DPCHANGE, handleAddReport);
252
+ emitter.on(DPCHANGE, handleAddReport);
253
+ handleAddTimeout(option.timeout);
254
+ };
255
+ export async function fitStartAddUnlockMethodForRuntime(rt, params) {
256
+ const cfg = rt.config;
257
+ const startedAt = Date.now();
258
+ sdkLog("info", "fitUnlockMethod", "startAddMethodStart", {
259
+ devId: rt.devId,
260
+ data: {
261
+ type: params.type,
262
+ userId: params.userId,
263
+ hasLockDevId: typeof params.lockDevId === "string",
264
+ },
265
+ });
266
+ const base = await getFitUnlockMethodBase(rt, params.type, params.userId, params.lockDevId);
267
+ const { unlockMethodConfig, lockUserId, lockDevId, slaveId, addDpCode, addDpMap, addDpReportMap, dpData, } = base;
268
+ const cfgItem = getUnlockMethodTypeByTypeForRuntime(rt, params.type);
269
+ const dpId = rt.config.idsByCode[cfgItem.code];
270
+ isCancelAddUnlockMethod = false;
271
+ const res = await publishDpsForRuntime(rt, {
272
+ [addDpCode]: dpUtils.format(dpData, addDpMap),
273
+ }, {
274
+ timeout: params.timeout,
275
+ checkReport: (dpDataIn) => {
276
+ if (typeof dpDataIn[addDpCode] === "undefined") {
277
+ return false;
278
+ }
279
+ const result = dpUtils.parse(dpDataIn[addDpCode], addDpReportMap);
280
+ let hasReport = result.type === unlockMethodConfig.id && result.slaveId === slaveId;
281
+ if (cfg.strictMode) {
282
+ hasReport = hasReport && result.memberId === lockUserId;
283
+ }
284
+ if (hasReport) {
285
+ if (result.memberId !== lockUserId) {
286
+ console.warn(`FitStartAddUnlockMethod: lockUserId mismatch, expected ${lockUserId}, got ${result.memberId}`);
287
+ sdkLog("warn", "fitUnlockMethod", "startAddMethodMemberMismatch", {
288
+ devId: rt.devId,
289
+ data: { type: params.type, lockDevId },
290
+ });
291
+ }
292
+ return result;
293
+ }
294
+ return false;
295
+ },
296
+ });
297
+ if (res.stage === 0) {
298
+ monitoringAddReport({
299
+ runtime: rt,
300
+ timeout: params.timeout,
301
+ unlockMethodConfig,
302
+ total: res.total,
303
+ dpCode: addDpCode,
304
+ dpMap: addDpReportMap,
305
+ slaveId,
306
+ lockDevId,
307
+ lockUserId,
308
+ userId: params.userId,
309
+ unlockDpId: dpId,
310
+ });
311
+ sdkLog("info", "fitUnlockMethod", "startAddMethodSuccess", {
312
+ devId: rt.devId,
313
+ duration: Date.now() - startedAt,
314
+ data: { type: params.type, lockDevId, total: res.total },
315
+ });
316
+ return { total: res.total };
317
+ }
318
+ if (res.stage === 0xfd) {
319
+ const error = getAddUnlockError(res.status);
320
+ sdkLog("warn", "fitUnlockMethod", "startAddMethodDpRejected", {
321
+ devId: rt.devId,
322
+ duration: Date.now() - startedAt,
323
+ data: { type: params.type, lockDevId, status: res.status },
324
+ error,
325
+ });
326
+ throw error;
327
+ }
328
+ const error = getError(1027);
329
+ sdkLog("warn", "fitUnlockMethod", "startAddMethodUnexpectedStage", {
330
+ devId: rt.devId,
331
+ duration: Date.now() - startedAt,
332
+ data: { type: params.type, lockDevId, stage: res.stage },
333
+ error,
334
+ });
335
+ throw error;
336
+ }
337
+ export const fitCancelAddUnlockMethodForRuntime = parallelOnlyForRuntime(async function fitCancelAddUnlockMethodForRuntime(rt, params) {
338
+ const cfg = rt.config;
339
+ const startedAt = Date.now();
340
+ sdkLog("info", "fitUnlockMethod", "cancelAddMethodStart", {
341
+ devId: rt.devId,
342
+ data: {
343
+ type: params.type,
344
+ userId: params.userId,
345
+ hasLockDevId: typeof params.lockDevId === "string",
346
+ },
347
+ });
348
+ const base = await getFitUnlockMethodBase(rt, params.type, params.userId, params.lockDevId);
349
+ const { unlockMethodConfig, lockUserId, slaveId, addDpCode, addDpMap, addDpReportMap, dpData, } = base;
350
+ dpData.stage = 0xfe;
351
+ isCancelAddUnlockMethod = true;
352
+ await publishDpsForRuntime(rt, {
353
+ [addDpCode]: dpUtils.format(dpData, addDpMap),
354
+ }, {
355
+ checkReport: (dpDataIn) => {
356
+ if (typeof dpDataIn[addDpCode] === "undefined") {
357
+ return false;
358
+ }
359
+ const result = dpUtils.parse(dpDataIn[addDpCode], addDpReportMap);
360
+ let hasReport = result.type === unlockMethodConfig.id &&
361
+ result.slaveId === slaveId;
362
+ if (cfg.strictMode) {
363
+ hasReport =
364
+ hasReport &&
365
+ result.stage === 0xfe &&
366
+ result.memberId === lockUserId;
367
+ }
368
+ if (hasReport) {
369
+ return result;
370
+ }
371
+ return false;
372
+ },
373
+ });
374
+ sdkLog("info", "fitUnlockMethod", "cancelAddMethodSuccess", {
375
+ devId: rt.devId,
376
+ duration: Date.now() - startedAt,
377
+ data: { type: params.type },
378
+ });
379
+ return;
380
+ });
@@ -0,0 +1,5 @@
1
+ import type { LockDeviceRuntime } from "../../../runtime/LockDeviceRuntime";
2
+ import type { FitAddUnlockMethodListener } from "./types";
3
+ export declare function getFitUnlockMethodEvent(runtime: LockDeviceRuntime): string;
4
+ export declare const onFitAddUnlockMethodForRuntime: (runtime: LockDeviceRuntime, listener: FitAddUnlockMethodListener) => void;
5
+ export declare const offFitAddUnlockMethodForRuntime: (runtime: LockDeviceRuntime, listener: FitAddUnlockMethodListener) => void;
@@ -0,0 +1,11 @@
1
+ import emitter from "../../../utils/event";
2
+ import { FIT_UNLOCK_METHOD_EVENT } from "../../../utils/constant";
3
+ export function getFitUnlockMethodEvent(runtime) {
4
+ return `${FIT_UNLOCK_METHOD_EVENT}_${runtime.devId}`;
5
+ }
6
+ export const onFitAddUnlockMethodForRuntime = (runtime, listener) => {
7
+ emitter.on(getFitUnlockMethodEvent(runtime), listener);
8
+ };
9
+ export const offFitAddUnlockMethodForRuntime = (runtime, listener) => {
10
+ emitter.off(getFitUnlockMethodEvent(runtime), listener);
11
+ };
@@ -0,0 +1,3 @@
1
+ import type { LockDeviceRuntime } from "../../../runtime/LockDeviceRuntime";
2
+ import type { FitAddPasswordParams } from "./types";
3
+ export declare function fitAddPasswordForRuntime(rt: LockDeviceRuntime, params: FitAddPasswordParams): Promise<void>;
@@ -0,0 +1,99 @@
1
+ import dpUtils from "@ray-js/tuya-dp-transform";
2
+ import { addFitOpenMode } from "../../../api/fit";
3
+ import { sleep } from "../../../utils";
4
+ import { getError, handleCloudError } from "../../../utils/errors";
5
+ import { publishDpsForRuntime } from "../../dp/publish-dps";
6
+ import { getFitUnlockMethodBase } from "./internal/base";
7
+ import { getAddUnlockError } from "../../unlock/method/internal/errors";
8
+ import { getUnlockMethodTypeByTypeForRuntime } from "../../utils";
9
+ import { sdkLog } from "../../../utils/sdk-log";
10
+ export async function fitAddPasswordForRuntime(rt, params) {
11
+ const cfg = rt.config;
12
+ const startedAt = Date.now();
13
+ sdkLog("info", "fitUnlockMethod", "addPasswordStart", {
14
+ devId: rt.devId,
15
+ data: {
16
+ userId: params.userId,
17
+ hasName: typeof params.name === "string",
18
+ hasLockDevId: typeof params.lockDevId === "string",
19
+ hijack: !!params.hijack,
20
+ },
21
+ });
22
+ if (!params.password) {
23
+ const error = getError(1054);
24
+ sdkLog("warn", "fitUnlockMethod", "addPasswordEmpty", {
25
+ devId: rt.devId,
26
+ error,
27
+ });
28
+ throw error;
29
+ }
30
+ const base = await getFitUnlockMethodBase(rt, "password", params.userId, params.lockDevId);
31
+ const { unlockMethodConfig, fittingId, lockDevId, slaveId, lockUserId, addDpCode, addDpMap, addDpReportMap, dpData, } = base;
32
+ dpData.pwdLength = params.password.length;
33
+ dpData.pwd = params.password.split("").map(Number);
34
+ const res = await publishDpsForRuntime(rt, {
35
+ [addDpCode]: dpUtils.format(dpData, addDpMap),
36
+ }, {
37
+ checkReport: (dpDataIn) => {
38
+ if (typeof dpDataIn[addDpCode] === "undefined") {
39
+ return false;
40
+ }
41
+ const result = dpUtils.parse(dpDataIn[addDpCode], addDpReportMap);
42
+ let hasReport = result.type === unlockMethodConfig.id &&
43
+ result.slaveId === slaveId &&
44
+ [0xff, 0xfd].includes(result.stage);
45
+ if (cfg.strictMode) {
46
+ hasReport = hasReport && result.memberId === lockUserId;
47
+ }
48
+ if (hasReport) {
49
+ if (result.memberId !== lockUserId) {
50
+ console.warn(`FitAddPassword: lockUserId mismatch, expected ${lockUserId}, got ${result.memberId}`);
51
+ sdkLog("warn", "fitUnlockMethod", "addPasswordMemberMismatch", {
52
+ devId: rt.devId,
53
+ data: { lockDevId },
54
+ });
55
+ }
56
+ return result;
57
+ }
58
+ return false;
59
+ },
60
+ });
61
+ if (res.stage === 0xfd) {
62
+ const error = getAddUnlockError(res.status);
63
+ sdkLog("warn", "fitUnlockMethod", "addPasswordDpRejected", {
64
+ devId: rt.devId,
65
+ duration: Date.now() - startedAt,
66
+ data: { status: res.status, lockDevId },
67
+ error,
68
+ });
69
+ throw error;
70
+ }
71
+ await sleep(300);
72
+ const cfgItem = getUnlockMethodTypeByTypeForRuntime(rt, "password");
73
+ const dpId = rt.config.idsByCode[cfgItem.code];
74
+ try {
75
+ await addFitOpenMode({
76
+ devIdList: [lockDevId],
77
+ fittingId,
78
+ unlockId: `${dpId}-${res.unlockId}`,
79
+ unlockName: params.name,
80
+ userId: params.userId,
81
+ hijack: !!params.hijack,
82
+ });
83
+ sdkLog("info", "fitUnlockMethod", "addPasswordSuccess", {
84
+ devId: rt.devId,
85
+ duration: Date.now() - startedAt,
86
+ data: { lockDevId },
87
+ });
88
+ return;
89
+ }
90
+ catch (error) {
91
+ sdkLog("error", "fitUnlockMethod", "addPasswordCloudFail", {
92
+ devId: rt.devId,
93
+ duration: Date.now() - startedAt,
94
+ data: { lockDevId },
95
+ error,
96
+ });
97
+ throw handleCloudError(error);
98
+ }
99
+ }
@@ -0,0 +1,19 @@
1
+ import type { DpMap } from "@ray-js/tuya-dp-transform";
2
+ import { fitAdd } from "../../../../config/dp-map/unlock-method-fit";
3
+ import type { DpMapDataType, UnlockMethodConfig, UnlockMethodType, UserInfo } from "../../../../interface";
4
+ import type { LockDeviceRuntime } from "../../../../runtime/LockDeviceRuntime";
5
+ export declare function buildValidConfigFromTimeSchedule(timeScheduleInfo: UserInfo["timeScheduleInfo"] | null | undefined): DpMapDataType<typeof fitAdd>["validConfig"];
6
+ export interface FitUnlockMethodBase {
7
+ unlockMethodConfig: UnlockMethodConfig;
8
+ fittingId: string;
9
+ lockDevId: string;
10
+ slaveId: number;
11
+ lockUserId: number;
12
+ userType: number;
13
+ lockUserInfo: UserInfo;
14
+ addDpCode: string;
15
+ addDpMap: DpMap;
16
+ addDpReportMap: DpMap;
17
+ dpData: DpMapDataType<typeof fitAdd>;
18
+ }
19
+ export declare function getFitUnlockMethodBase(rt: LockDeviceRuntime, type: UnlockMethodType, userId: string, lockDevId?: string): Promise<FitUnlockMethodBase>;