@ray-js/lock-sdk 1.1.3 → 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
@@ -1,701 +0,0 @@
1
- import dpUtils from "@ray-js/tuya-dp-transform";
2
- import { bindUnlockMethodToUser, bindUnlockMethodToUserByRecord, checkFreeUnlockMethods, createUnlockMethod, removeUnlockMethod, editUnlockMethod, fetchCreatePasswordSN, fetchFreeUnlockMethods, getUnlockMethodInfo, unbindMemberUnlockMethod, } from "./api/lock";
3
- import config from "./config";
4
- import dpCodes from "./config/dp-code";
5
- import { add as addMap, reportAdd as reportAddMap, remove as removeMap, reportRemove as reportRemoveMap, } from "./config/dp-map/unlock-method";
6
- import { add as addBigMap, reportAdd as reportAddBigMap, remove as removeBigMap, reportRemove as reportRemoveBigMap, } from "./config/dp-map/unlock-method-big";
7
- import { getPermanentSetting, getUnlockMethodTypeByDpCode, getUnlockMethodTypeByType, isAdmin, parallelOnly, sleep, } from "./utils";
8
- import { getError } from "./utils/errors";
9
- import { publishDps } from "./utils/publishDps";
10
- import { encrypt } from "./utils/device";
11
- import emitter from "./utils/event";
12
- import { DPCHANGE, LoopTypes, UNLOCK_METHOD_EVENT } from "./utils/constant";
13
- import { getFileRemoteUrl, sendPhoneVerifyCode } from "./api";
14
- import { getUserInfo } from "./user";
15
- import { getDeviceAdvancedAbilities } from "./capability";
16
- const getAddUnlockError = (status) => {
17
- if (status >= 0 && status <= 10) {
18
- return getError(1015 + status);
19
- }
20
- if (status === 0xfe) {
21
- return getError(1026);
22
- }
23
- return {
24
- ...getError(1016),
25
- devCode: status,
26
- };
27
- };
28
- export const getUnlockMethodDetail = async (id) => {
29
- const cloudData = await getUnlockMethodInfo({
30
- devId: config.devInfo.devId,
31
- opModeId: id,
32
- });
33
- const detail = {
34
- isBound: cloudData.allocateFlag === 1,
35
- type: getUnlockMethodTypeByDpCode(config.codesById[Number(cloudData.opmode)])?.type,
36
- phase: cloudData.phase,
37
- dpId: Number(cloudData.opmode),
38
- isSpecial: cloudData.unlockAttr === 1,
39
- unlockName: cloudData.unlockName,
40
- userId: cloudData.userId,
41
- unlockId: Number(cloudData.opmodeValue),
42
- lockUserId: cloudData.lockUserId,
43
- id: cloudData.opmodeId,
44
- userType: cloudData.userType,
45
- notifyInfo: {
46
- appSend: !!cloudData.notifyInfo?.appSend,
47
- msgSend: !!cloudData.notifyInfo?.msgPhone,
48
- msgPhone: cloudData.notifyInfo?.msgPhone,
49
- countryCode: cloudData.notifyInfo?.countryCode,
50
- },
51
- };
52
- return detail;
53
- };
54
- const getUnlockMethodBase = async (type, userId) => {
55
- const { idsByCode, devInfo: { devId }, supportBigData, } = config;
56
- const unlockMethodConfig = getUnlockMethodTypeByType(type);
57
- const addDpCode = supportBigData
58
- ? dpCodes.unlockMethodCreateW
59
- : dpCodes.unlockMethodCreate;
60
- const dpId = idsByCode[unlockMethodConfig.code];
61
- const [user, sn] = await Promise.all([
62
- getUserInfo({
63
- userId: userId,
64
- }),
65
- fetchCreatePasswordSN({
66
- devId: devId,
67
- dpId,
68
- }),
69
- ]);
70
- const { userType, lockUserId, timeScheduleInfo } = user;
71
- let validConfig;
72
- if (timeScheduleInfo) {
73
- const { permanent, effectiveTime, expiredTime, scheduleDetails } = timeScheduleInfo;
74
- if (permanent) {
75
- validConfig = {
76
- startTime: effectiveTime
77
- ? Math.floor(effectiveTime / 1000)
78
- : 0x386cd300,
79
- endTime: expiredTime ? Math.floor(expiredTime / 1000) : 0x72bc9b7f,
80
- loop: LoopTypes.NONE,
81
- loopConfig: 0,
82
- weeks: [0, 0, 0, 0, 0, 0, 0],
83
- days: [],
84
- startHour: 0,
85
- startMinute: 0,
86
- endHour: 0,
87
- endMinute: 0,
88
- };
89
- }
90
- else {
91
- validConfig = {
92
- startTime: Math.floor((effectiveTime || +new Date()) / 1000),
93
- endTime: expiredTime ? Math.floor(expiredTime / 1000) : 0x72bc9b7f,
94
- loop: scheduleDetails?.repeat ? LoopTypes.WEEK : LoopTypes.NONE,
95
- loopConfig: 0,
96
- weeks: scheduleDetails?.repeat
97
- ? scheduleDetails?.weeks
98
- : [0, 0, 0, 0, 0, 0, 0],
99
- days: [],
100
- startHour: Math.floor((scheduleDetails?.effectiveTime ?? 0) / 60),
101
- startMinute: (scheduleDetails?.effectiveTime ?? 0) % 60,
102
- endHour: Math.floor((scheduleDetails?.invalidTime ?? 0) / 60),
103
- endMinute: (scheduleDetails?.invalidTime ?? 0) % 60,
104
- };
105
- }
106
- }
107
- else {
108
- validConfig = getPermanentSetting();
109
- }
110
- const dpData = {
111
- type: unlockMethodConfig.id,
112
- stage: 0,
113
- admin: isAdmin(userType),
114
- memberId: lockUserId,
115
- unlockId: supportBigData ? 0xffff : 0xff,
116
- validConfig,
117
- validNum: 0,
118
- pwdLength: 0,
119
- pwd: [],
120
- sn,
121
- };
122
- return {
123
- unlockMethodConfig,
124
- devId,
125
- userType,
126
- lockUserId,
127
- sn,
128
- dpId,
129
- addDpCode,
130
- addDpMap: (supportBigData ? addBigMap : addMap),
131
- addDpReportMap: (supportBigData ? reportAddBigMap : reportAddMap),
132
- dpData,
133
- };
134
- };
135
- const checkSpecial = (isSpecial, params, oldSetting) => {
136
- const supportedPhone = checkSpecialSupportPhone();
137
- if (isSpecial) {
138
- if (!params?.appSend) {
139
- if (!supportedPhone) {
140
- throw getError(1057);
141
- }
142
- else if (!params?.msgSend) {
143
- throw getError(1058);
144
- }
145
- }
146
- if (supportedPhone && params?.msgSend) {
147
- if (!params.msgPhone) {
148
- throw getError(1066);
149
- }
150
- if (!params.countryCode) {
151
- throw getError(1056);
152
- }
153
- if (params.msgPhone !== oldSetting?.msgPhone && !params.verifyCode) {
154
- throw getError(1055);
155
- }
156
- }
157
- }
158
- return {
159
- unlockAttr: isSpecial ? 1 : 0,
160
- notifyInfo: {
161
- appSend: !!params?.appSend,
162
- msgPhone: supportedPhone && params?.msgSend ? params?.msgPhone : undefined,
163
- countryCode: supportedPhone && params?.msgSend ? params?.countryCode : undefined,
164
- msgPhoneVerifyCode: supportedPhone && params?.msgSend ? params?.verifyCode : undefined,
165
- },
166
- };
167
- };
168
- export const checkSpecialSupportPhone = () => {
169
- return !!config.dpSchema[dpCodes.message];
170
- };
171
- export const addPassword = async (params) => {
172
- if (!params.password) {
173
- throw getError(1054);
174
- }
175
- const specialInfo = checkSpecial(!!params.isSpecial, params.specialInfo);
176
- const { lockUserId, dpData, sn, addDpCode, addDpMap, addDpReportMap, devId, dpId, unlockMethodConfig, } = await getUnlockMethodBase("password", params.userId);
177
- dpData.pwdLength = params.password.length;
178
- dpData.pwd = params.password.split("").map(Number);
179
- const res = await publishDps({
180
- [addDpCode]: dpUtils.format(dpData, addDpMap),
181
- }, {
182
- checkReport: (dpData) => {
183
- if (typeof dpData[addDpCode] !== "undefined") {
184
- const result = dpUtils.parse(dpData[addDpCode], addDpReportMap);
185
- let hasReport = result.type === unlockMethodConfig.id &&
186
- [0xff, 0xfd].includes(result.stage);
187
- if (config.strictMode) {
188
- hasReport =
189
- hasReport && result.memberId === lockUserId && result.sn === sn;
190
- }
191
- if (hasReport) {
192
- if (result.memberId !== lockUserId) {
193
- console.warn(`AddPassword: lockUserId mismatch, expected ${lockUserId}, got ${result.memberId}`);
194
- }
195
- return result;
196
- }
197
- return false;
198
- }
199
- console.warn("AddPassword: An invalid value may have been reported");
200
- return false;
201
- },
202
- });
203
- if (res.stage === 0xfd) {
204
- throw getAddUnlockError(res.status);
205
- }
206
- const aesPwd = await encrypt(devId, params.password);
207
- await sleep(300);
208
- return await createUnlockMethod({
209
- devId: devId,
210
- userId: params.userId,
211
- unlockId: `${dpId}-${res.unlockId}`,
212
- unlockName: params.name,
213
- unlockDetail: aesPwd,
214
- ...specialInfo,
215
- });
216
- };
217
- const addUnlockMethodData = {
218
- unlockMethodConfig: {},
219
- total: 0,
220
- dpCode: "",
221
- dpMap: {},
222
- sn: 0,
223
- lockUserId: 0,
224
- timeoutId: 0,
225
- userId: "",
226
- unlockDpId: 0,
227
- timeout: 15000,
228
- canEmitEvents: true,
229
- pendingEvents: [],
230
- releaseEmitTimer: 0,
231
- eventSessionId: 0,
232
- };
233
- const ADD_UNLOCK_METHOD_EVENT_RELEASE_DELAY = 16;
234
- const dispatchAddUnlockMethodEvent = (eventData) => {
235
- if (emitter.hasListener(UNLOCK_METHOD_EVENT)) {
236
- emitter.emit(UNLOCK_METHOD_EVENT, eventData);
237
- }
238
- else {
239
- emitter.cache(UNLOCK_METHOD_EVENT, eventData);
240
- }
241
- };
242
- const emitAddUnlockMethodEvent = (eventData) => {
243
- if (!addUnlockMethodData.canEmitEvents) {
244
- addUnlockMethodData.pendingEvents.push(eventData);
245
- return;
246
- }
247
- dispatchAddUnlockMethodEvent(eventData);
248
- };
249
- const releaseAddUnlockMethodEventsAfterStart = (eventSessionId) => {
250
- clearTimeout(addUnlockMethodData.releaseEmitTimer);
251
- addUnlockMethodData.releaseEmitTimer = setTimeout(() => {
252
- if (addUnlockMethodData.eventSessionId !== eventSessionId) {
253
- return;
254
- }
255
- addUnlockMethodData.releaseEmitTimer = setTimeout(() => {
256
- if (addUnlockMethodData.eventSessionId !== eventSessionId) {
257
- return;
258
- }
259
- addUnlockMethodData.canEmitEvents = true;
260
- const pendingEvents = addUnlockMethodData.pendingEvents.splice(0);
261
- pendingEvents.forEach((eventData) => {
262
- dispatchAddUnlockMethodEvent(eventData);
263
- });
264
- }, ADD_UNLOCK_METHOD_EVENT_RELEASE_DELAY);
265
- }, 0);
266
- };
267
- const handleAddTimeout = (timeout = 15000) => {
268
- clearTimeout(addUnlockMethodData.timeoutId);
269
- addUnlockMethodData.timeoutId = setTimeout(() => {
270
- emitter.off(DPCHANGE, handleAddReport);
271
- emitAddUnlockMethodEvent({
272
- type: addUnlockMethodData.unlockMethodConfig.type,
273
- stage: "fail",
274
- lockUserId: addUnlockMethodData.lockUserId,
275
- error: getError(1002),
276
- });
277
- }, timeout);
278
- };
279
- const handleAddReport = async (dps) => {
280
- if (dps[addUnlockMethodData.dpCode]) {
281
- const result = dpUtils.parse(dps[addUnlockMethodData.dpCode], addUnlockMethodData.dpMap);
282
- let eventData = null;
283
- if (result.type !== addUnlockMethodData.unlockMethodConfig.id) {
284
- return;
285
- }
286
- if (config.strictMode) {
287
- if (result.sn !== addUnlockMethodData.sn ||
288
- result.memberId !== addUnlockMethodData.lockUserId) {
289
- return;
290
- }
291
- }
292
- else {
293
- if (result.sn !== addUnlockMethodData.sn) {
294
- console.warn(`AddUnlockMethod: sn mismatch, expected ${addUnlockMethodData.sn}, got ${result.sn}`);
295
- }
296
- if (result.memberId !== addUnlockMethodData.lockUserId) {
297
- console.warn(`AddUnlockMethod: lockUserId mismatch, expected ${addUnlockMethodData.lockUserId}, got ${result.memberId}`);
298
- }
299
- }
300
- const type = addUnlockMethodData.unlockMethodConfig.type;
301
- switch (result.stage) {
302
- case 0xfc: {
303
- handleAddTimeout(addUnlockMethodData.timeout);
304
- eventData = {
305
- type,
306
- stage: "step",
307
- lockUserId: result.memberId,
308
- step: result.step,
309
- total: addUnlockMethodData.total,
310
- };
311
- break;
312
- }
313
- case 0xfd: {
314
- clearMonitoringAddReport();
315
- eventData = {
316
- stage: "fail",
317
- type,
318
- lockUserId: result.memberId,
319
- error: getAddUnlockError(result.status),
320
- };
321
- break;
322
- }
323
- case 0xfe: {
324
- clearMonitoringAddReport();
325
- if (isCancelAddUnlockMethod) {
326
- isCancelAddUnlockMethod = false;
327
- return;
328
- }
329
- eventData = {
330
- stage: "fail",
331
- type,
332
- lockUserId: result.memberId,
333
- error: getAddUnlockError(result.status),
334
- };
335
- break;
336
- }
337
- case 0xff: {
338
- clearMonitoringAddReport();
339
- try {
340
- await sleep(300);
341
- let isAddEnabled = true;
342
- if (!config.supportMultipleFace && type === "face") {
343
- const user = await getUserInfo({
344
- userId: addUnlockMethodData.userId,
345
- });
346
- const faceData = user.unlockDetails.find((item) => item.type === "face" && item.unlockList.length > 0);
347
- if (faceData) {
348
- const originUnlockId = faceData.unlockList[0].unlockId;
349
- if (originUnlockId !== result.unlockId) {
350
- eventData = {
351
- stage: "fail",
352
- type,
353
- lockUserId: result.memberId,
354
- error: getError(1061),
355
- };
356
- }
357
- else {
358
- eventData = {
359
- stage: "success",
360
- type,
361
- id: faceData.unlockList[0].id,
362
- name: faceData.unlockList[0].unlockName,
363
- };
364
- }
365
- isAddEnabled = false;
366
- }
367
- }
368
- if (isAddEnabled) {
369
- const res = await createUnlockMethod({
370
- devId: config.devInfo.devId,
371
- userId: addUnlockMethodData.userId,
372
- unlockId: `${addUnlockMethodData.unlockDpId}-${result.unlockId}`,
373
- unlockName: "",
374
- unlockAttr: 0,
375
- });
376
- eventData = {
377
- stage: "success",
378
- type,
379
- id: res.opModeId,
380
- name: res.unlockName,
381
- };
382
- }
383
- }
384
- catch (err) {
385
- console.warn("AddUnlockMethod failed", err);
386
- eventData = {
387
- stage: "fail",
388
- type,
389
- lockUserId: result.memberId,
390
- error: getError(1053),
391
- };
392
- }
393
- break;
394
- }
395
- default:
396
- }
397
- if (eventData) {
398
- emitAddUnlockMethodEvent(eventData);
399
- }
400
- }
401
- };
402
- const clearMonitoringAddReport = () => {
403
- clearTimeout(addUnlockMethodData.timeoutId);
404
- emitter.off(DPCHANGE, handleAddReport);
405
- };
406
- const monitoringAddReport = (option) => {
407
- Object.assign(addUnlockMethodData, option);
408
- clearTimeout(addUnlockMethodData.releaseEmitTimer);
409
- addUnlockMethodData.canEmitEvents = false;
410
- addUnlockMethodData.pendingEvents = [];
411
- addUnlockMethodData.eventSessionId += 1;
412
- emitter.clearCache(UNLOCK_METHOD_EVENT);
413
- emitter.off(DPCHANGE, handleAddReport);
414
- emitter.on(DPCHANGE, handleAddReport);
415
- handleAddTimeout(option.timeout);
416
- return addUnlockMethodData.eventSessionId;
417
- };
418
- export const startAddUnlockMethod = async (params) => {
419
- const { unlockMethodConfig, lockUserId, dpData, sn, addDpCode, addDpMap, addDpReportMap, dpId, } = await getUnlockMethodBase(params.type, params.userId);
420
- isCancelAddUnlockMethod = false;
421
- let addReportMonitoringStarted = false;
422
- let addReportMonitoringSessionId = 0;
423
- const startAddReportMonitoring = (total) => {
424
- if (addReportMonitoringStarted) {
425
- return addReportMonitoringSessionId;
426
- }
427
- addReportMonitoringStarted = true;
428
- addReportMonitoringSessionId = monitoringAddReport({
429
- timeout: params.timeout,
430
- unlockMethodConfig,
431
- total,
432
- dpCode: addDpCode,
433
- dpMap: addDpReportMap,
434
- sn,
435
- lockUserId,
436
- userId: params.userId,
437
- unlockDpId: dpId,
438
- });
439
- return addReportMonitoringSessionId;
440
- };
441
- const res = await publishDps({
442
- [addDpCode]: dpUtils.format(dpData, addDpMap),
443
- }, {
444
- timeout: params.timeout,
445
- checkReport: (dpData) => {
446
- if (typeof dpData[addDpCode] !== "undefined") {
447
- const result = dpUtils.parse(dpData[addDpCode], addDpReportMap);
448
- let hasReport = result.type === unlockMethodConfig.id;
449
- if (config.strictMode) {
450
- hasReport =
451
- hasReport && result.memberId === lockUserId && result.sn === sn;
452
- }
453
- if (hasReport) {
454
- if (result.memberId !== lockUserId) {
455
- console.warn(`StartAddUnlockMethod: lockUserId mismatch, expected ${lockUserId}, got ${result.memberId}`);
456
- }
457
- if (result.sn !== sn) {
458
- console.warn("AddPassword: An invalid sn may have been reported");
459
- }
460
- if (result.stage === 0) {
461
- startAddReportMonitoring(result.total);
462
- }
463
- return result;
464
- }
465
- return false;
466
- }
467
- console.warn("AddPassword: An invalid value may have been reported");
468
- return false;
469
- },
470
- });
471
- if (res.stage === 0) {
472
- const eventSessionId = startAddReportMonitoring(res.total);
473
- releaseAddUnlockMethodEventsAfterStart(eventSessionId);
474
- return { total: res.total };
475
- }
476
- if (res.stage === 0xfd) {
477
- throw getAddUnlockError(res.status);
478
- }
479
- throw getError(1027);
480
- };
481
- export const updateUnlockMethod = async (params) => {
482
- const detail = await getUnlockMethodDetail(params.id);
483
- const specialInfo = checkSpecial(!!params.isSpecial, params.specialInfo, detail.notifyInfo);
484
- return await editUnlockMethod({
485
- devId: config.devInfo.devId,
486
- opModeId: params.id,
487
- unlockName: params.name,
488
- ...specialInfo,
489
- });
490
- };
491
- let isCancelAddUnlockMethod = false;
492
- export const cancelAddUnlockMethod = parallelOnly(async (params) => {
493
- const { dpData, addDpCode, addDpMap, addDpReportMap, unlockMethodConfig, lockUserId, sn, } = await getUnlockMethodBase(params.type, params.userId);
494
- dpData.stage = 0xfe;
495
- isCancelAddUnlockMethod = true;
496
- await publishDps({
497
- [addDpCode]: dpUtils.format(dpData, addDpMap),
498
- }, {
499
- checkReport: (dpData) => {
500
- if (typeof dpData[addDpCode] !== "undefined") {
501
- const result = dpUtils.parse(dpData[addDpCode], addDpReportMap);
502
- let hasReport = result.type === unlockMethodConfig.id;
503
- if (config.strictMode) {
504
- hasReport =
505
- hasReport &&
506
- result.stage === 0xfe &&
507
- result.memberId === lockUserId &&
508
- result.sn === sn;
509
- }
510
- if (hasReport) {
511
- return result;
512
- }
513
- console.warn("CancelAddUnlockMethod: An invalid value may have been reported");
514
- }
515
- return false;
516
- },
517
- });
518
- return true;
519
- });
520
- export const deleteUnlockMethod = parallelOnly(async (id) => {
521
- const { lockUserId, unlockId, userType, dpId } = await getUnlockMethodDetail(id);
522
- const dpCode = config.codesById[dpId];
523
- const unlockMethodConfig = getUnlockMethodTypeByDpCode(dpCode);
524
- const removeDPCode = config.supportBigData
525
- ? dpCodes.unlockMethodDelW
526
- : dpCodes.unlockMethodDel;
527
- if (!config.dpSchema[removeDPCode]) {
528
- throw getError(1014);
529
- }
530
- const dpData = {
531
- type: unlockMethodConfig.id,
532
- stage: 0,
533
- admin: isAdmin(userType),
534
- memberId: lockUserId,
535
- unlockId,
536
- operation: 1,
537
- };
538
- const res = await publishDps({
539
- [removeDPCode]: dpUtils.format(dpData, (config.supportBigData ? removeBigMap : removeMap)),
540
- }, {
541
- checkReport: (dpData) => {
542
- if (typeof dpData[removeDPCode] !== "undefined") {
543
- const result = dpUtils.parse(dpData[removeDPCode], (config.supportBigData
544
- ? reportRemoveBigMap
545
- : reportRemoveMap));
546
- let hasReport = result.type === unlockMethodConfig.id;
547
- if (config.strictMode) {
548
- hasReport =
549
- hasReport &&
550
- result.stage === 0 &&
551
- result.memberId === lockUserId &&
552
- result.unlockId === unlockId;
553
- }
554
- if (hasReport) {
555
- if (result.unlockId !== unlockId) {
556
- console.warn(`RemoveUnlockMethod: unlockId mismatch, expected ${unlockId}, got ${result.unlockId}`);
557
- }
558
- return result;
559
- }
560
- console.warn("RemoveUnlockMethod: An invalid value may have been reported");
561
- }
562
- return false;
563
- },
564
- });
565
- if (res.status !== 255 && res.status !== 1) {
566
- switch (res.status) {
567
- case 2:
568
- throw getError(1029);
569
- case 0:
570
- default:
571
- throw getError(1028);
572
- }
573
- }
574
- await removeUnlockMethod({
575
- devId: config.devInfo.devId,
576
- opmodeId: id,
577
- });
578
- });
579
- export const checkUnBindUnlockMethods = async () => {
580
- const data = await checkFreeUnlockMethods({
581
- devId: config.devInfo.devId,
582
- });
583
- return data === true || data === 1;
584
- };
585
- export const getUnbindUnlockMethods = async () => {
586
- const cloudData = await fetchFreeUnlockMethods({
587
- devId: config.devInfo.devId,
588
- });
589
- const list = cloudData.map((item) => {
590
- const unlockMethodConfig = getUnlockMethodTypeByDpCode(item.standardDp);
591
- return {
592
- type: unlockMethodConfig.type,
593
- list: item.unlockInfo.map((unlock) => {
594
- return {
595
- unlockId: Number(unlock.unlockId.split("-")[1]),
596
- unlockName: unlock.unlockName,
597
- id: unlock.opmodeId,
598
- unlockSn: unlock.unlockSn,
599
- type: unlockMethodConfig.type,
600
- dpId: Number(item.opmode),
601
- dpCode: item.standardDp,
602
- };
603
- }),
604
- };
605
- });
606
- return list;
607
- };
608
- export const bindUnlockMethod = (params) => {
609
- const unlockIds = params.unlockList.map((item) => {
610
- const unlockMethodConfig = getUnlockMethodTypeByType(item.type);
611
- const dpId = config.idsByCode[unlockMethodConfig.code];
612
- return `${dpId}-${item.unlockId}`;
613
- });
614
- return bindUnlockMethodToUser({
615
- devId: config.devInfo.devId,
616
- userId: params.userId,
617
- unlockIds: unlockIds,
618
- });
619
- };
620
- export const unbindUnlockMethod = async (id) => {
621
- const detail = await getUnlockMethodDetail(id);
622
- if (!detail.isBound) {
623
- throw getError(1050);
624
- }
625
- return unbindMemberUnlockMethod({
626
- devId: config.devInfo.devId,
627
- userId: detail.userId,
628
- unlockIds: [`${detail.dpId}-${detail.unlockId}`],
629
- });
630
- };
631
- export const bindUnlockMethodFromLog = (params) => {
632
- const { idsByCode } = config;
633
- const unlockIds = params.unlockList.map((item) => {
634
- const unlockMethodConfig = getUnlockMethodTypeByType(item.type);
635
- const dpId = idsByCode[unlockMethodConfig.code];
636
- return `${dpId}-${item.unlockId}`;
637
- });
638
- return bindUnlockMethodToUserByRecord({
639
- devId: config.devInfo.devId,
640
- userId: params.userId,
641
- unlockIds: unlockIds,
642
- });
643
- };
644
- export const sendVerifyCode = (params) => {
645
- return sendPhoneVerifyCode({
646
- ...params,
647
- devId: config.devInfo.devId,
648
- });
649
- };
650
- export const onAddUnlockMethod = (listener) => {
651
- emitter.on(UNLOCK_METHOD_EVENT, listener);
652
- };
653
- export const offAddUnlockMethod = (listener) => {
654
- emitter.off(UNLOCK_METHOD_EVENT, listener);
655
- };
656
- const guileTypeMap = {
657
- card: ["addCard", "addCardPic"],
658
- finger: ["addFingerprint", "addFingerprintPic"],
659
- face: ["addFace", "addFacePic"],
660
- fingerVein: ["addFingervein", "addFingerveinPic"],
661
- hand: ["addPalmvein", "addPalmveinPic"],
662
- eye: ["addIris", "addIrisPic"],
663
- };
664
- export const getUnlockGuide = async (type) => {
665
- if (type === "password") {
666
- return null;
667
- }
668
- const { unlockGuide } = await getDeviceAdvancedAbilities();
669
- if (unlockGuide.support) {
670
- const [videoKey, picKey] = guileTypeMap[type] || ["", ""];
671
- const resources = [];
672
- let videoUrlPath = "";
673
- let picUrlPath = "";
674
- if (unlockGuide.config[picKey]) {
675
- picUrlPath = unlockGuide.config[picKey].url;
676
- resources.push({
677
- objectKey: picUrlPath,
678
- });
679
- }
680
- if (unlockGuide.config[videoKey]) {
681
- videoUrlPath = unlockGuide.config[videoKey].url;
682
- resources.push({
683
- objectKey: videoUrlPath,
684
- });
685
- }
686
- if (resources.length === 0) {
687
- return null;
688
- }
689
- const { signedUrls } = await getFileRemoteUrl({
690
- biz: "hulk_video_tutorial_video",
691
- resources,
692
- });
693
- const expireTime = Date.now() + 30 * 60 * 1000;
694
- return {
695
- videoUrl: signedUrls[videoUrlPath],
696
- picUrl: signedUrls[picUrlPath],
697
- expireTime,
698
- };
699
- }
700
- return null;
701
- };