@unwanted/matrix-sdk-mini 34.12.0 → 34.13.0

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 (698) hide show
  1. package/git-revision.txt +1 -1
  2. package/lib/@types/event.d.ts +0 -19
  3. package/lib/@types/event.d.ts.map +1 -1
  4. package/lib/@types/event.js.map +1 -1
  5. package/lib/@types/global.d.js +0 -2
  6. package/lib/@types/global.d.js.map +1 -1
  7. package/lib/autodiscovery.d.ts +1 -1
  8. package/lib/autodiscovery.d.ts.map +1 -1
  9. package/lib/autodiscovery.js.map +1 -1
  10. package/lib/base64.d.ts +3 -6
  11. package/lib/base64.d.ts.map +1 -1
  12. package/lib/base64.js +43 -36
  13. package/lib/base64.js.map +1 -1
  14. package/lib/browser-index.d.ts.map +1 -1
  15. package/lib/browser-index.js +0 -11
  16. package/lib/browser-index.js.map +1 -1
  17. package/lib/client.d.ts +2 -1298
  18. package/lib/client.d.ts.map +1 -1
  19. package/lib/client.js +348 -2967
  20. package/lib/client.js.map +1 -1
  21. package/lib/digest.d.ts +2 -2
  22. package/lib/digest.d.ts.map +1 -1
  23. package/lib/digest.js +2 -2
  24. package/lib/digest.js.map +1 -1
  25. package/lib/embedded.d.ts +0 -22
  26. package/lib/embedded.d.ts.map +1 -1
  27. package/lib/embedded.js +58 -168
  28. package/lib/embedded.js.map +1 -1
  29. package/lib/event-mapper.d.ts.map +1 -1
  30. package/lib/event-mapper.js +0 -4
  31. package/lib/event-mapper.js.map +1 -1
  32. package/lib/matrix.d.ts +0 -25
  33. package/lib/matrix.d.ts.map +1 -1
  34. package/lib/matrix.js +1 -30
  35. package/lib/matrix.js.map +1 -1
  36. package/lib/models/MSC3089Branch.d.ts.map +1 -1
  37. package/lib/models/MSC3089Branch.js +0 -3
  38. package/lib/models/MSC3089Branch.js.map +1 -1
  39. package/lib/models/event-timeline-set.d.ts +6 -10
  40. package/lib/models/event-timeline-set.d.ts.map +1 -1
  41. package/lib/models/event-timeline-set.js +28 -36
  42. package/lib/models/event-timeline-set.js.map +1 -1
  43. package/lib/models/event-timeline.d.ts +7 -2
  44. package/lib/models/event-timeline.d.ts.map +1 -1
  45. package/lib/models/event-timeline.js +8 -9
  46. package/lib/models/event-timeline.js.map +1 -1
  47. package/lib/models/event.d.ts +1 -95
  48. package/lib/models/event.d.ts.map +1 -1
  49. package/lib/models/event.js +11 -281
  50. package/lib/models/event.js.map +1 -1
  51. package/lib/models/poll.d.ts.map +1 -1
  52. package/lib/models/poll.js +1 -5
  53. package/lib/models/poll.js.map +1 -1
  54. package/lib/models/relations-container.d.ts.map +1 -1
  55. package/lib/models/relations-container.js +1 -7
  56. package/lib/models/relations-container.js.map +1 -1
  57. package/lib/models/relations.d.ts +0 -1
  58. package/lib/models/relations.d.ts.map +1 -1
  59. package/lib/models/relations.js +0 -8
  60. package/lib/models/relations.js.map +1 -1
  61. package/lib/models/room-state.d.ts +2 -13
  62. package/lib/models/room-state.d.ts.map +1 -1
  63. package/lib/models/room-state.js +12 -56
  64. package/lib/models/room-state.js.map +1 -1
  65. package/lib/models/room.d.ts +2 -20
  66. package/lib/models/room.d.ts.map +1 -1
  67. package/lib/models/room.js +121 -162
  68. package/lib/models/room.js.map +1 -1
  69. package/lib/models/thread.d.ts.map +1 -1
  70. package/lib/models/thread.js +5 -4
  71. package/lib/models/thread.js.map +1 -1
  72. package/lib/sliding-sync-sdk.d.ts +3 -4
  73. package/lib/sliding-sync-sdk.d.ts.map +1 -1
  74. package/lib/sliding-sync-sdk.js +55 -102
  75. package/lib/sliding-sync-sdk.js.map +1 -1
  76. package/lib/sliding-sync.js +9 -6
  77. package/lib/sliding-sync.js.map +1 -1
  78. package/lib/store/indexeddb.d.ts +1 -1
  79. package/lib/store/indexeddb.d.ts.map +1 -1
  80. package/lib/store/indexeddb.js.map +1 -1
  81. package/lib/sync-accumulator.d.ts +6 -4
  82. package/lib/sync-accumulator.d.ts.map +1 -1
  83. package/lib/sync-accumulator.js +23 -12
  84. package/lib/sync-accumulator.js.map +1 -1
  85. package/lib/sync.d.ts +10 -13
  86. package/lib/sync.d.ts.map +1 -1
  87. package/lib/sync.js +94 -115
  88. package/lib/sync.js.map +1 -1
  89. package/lib/testing.d.ts +0 -48
  90. package/lib/testing.d.ts.map +1 -1
  91. package/lib/testing.js +0 -105
  92. package/lib/testing.js.map +1 -1
  93. package/lib/types.d.ts +0 -1
  94. package/lib/types.d.ts.map +1 -1
  95. package/lib/types.js.map +1 -1
  96. package/package.json +10 -11
  97. package/src/@types/event.ts +2 -36
  98. package/src/@types/global.d.ts +21 -4
  99. package/src/autodiscovery.ts +1 -1
  100. package/src/base64.ts +38 -40
  101. package/src/browser-index.ts +0 -11
  102. package/src/client.ts +68 -3087
  103. package/src/digest.ts +3 -3
  104. package/src/embedded.ts +38 -134
  105. package/src/event-mapper.ts +0 -4
  106. package/src/matrix.ts +0 -41
  107. package/src/models/MSC3089Branch.ts +0 -3
  108. package/src/models/event-timeline-set.ts +17 -38
  109. package/src/models/event-timeline.ts +10 -5
  110. package/src/models/event.ts +8 -295
  111. package/src/models/poll.ts +0 -6
  112. package/src/models/relations-container.ts +1 -8
  113. package/src/models/relations.ts +0 -8
  114. package/src/models/room-state.ts +4 -37
  115. package/src/models/room.ts +18 -68
  116. package/src/models/thread.ts +4 -3
  117. package/src/sliding-sync-sdk.ts +10 -83
  118. package/src/sliding-sync.ts +6 -6
  119. package/src/store/indexeddb.ts +1 -1
  120. package/src/sync-accumulator.ts +33 -16
  121. package/src/sync.ts +112 -143
  122. package/src/testing.ts +0 -108
  123. package/src/types.ts +0 -1
  124. package/CHANGELOG.md +0 -5910
  125. package/lib/@types/AESEncryptedSecretStoragePayload.d.ts +0 -14
  126. package/lib/@types/AESEncryptedSecretStoragePayload.d.ts.map +0 -1
  127. package/lib/@types/AESEncryptedSecretStoragePayload.js +0 -1
  128. package/lib/@types/AESEncryptedSecretStoragePayload.js.map +0 -1
  129. package/lib/@types/crypto.d.ts +0 -47
  130. package/lib/@types/crypto.d.ts.map +0 -1
  131. package/lib/@types/crypto.js +0 -1
  132. package/lib/@types/crypto.js.map +0 -1
  133. package/lib/@types/matrix-sdk-crypto-wasm.d.js +0 -1
  134. package/lib/@types/matrix-sdk-crypto-wasm.d.js.map +0 -1
  135. package/lib/common-crypto/CryptoBackend.d.ts +0 -240
  136. package/lib/common-crypto/CryptoBackend.d.ts.map +0 -1
  137. package/lib/common-crypto/CryptoBackend.js +0 -73
  138. package/lib/common-crypto/CryptoBackend.js.map +0 -1
  139. package/lib/common-crypto/key-passphrase.d.ts +0 -14
  140. package/lib/common-crypto/key-passphrase.d.ts.map +0 -1
  141. package/lib/common-crypto/key-passphrase.js +0 -33
  142. package/lib/common-crypto/key-passphrase.js.map +0 -1
  143. package/lib/crypto/CrossSigning.d.ts +0 -184
  144. package/lib/crypto/CrossSigning.d.ts.map +0 -1
  145. package/lib/crypto/CrossSigning.js +0 -718
  146. package/lib/crypto/CrossSigning.js.map +0 -1
  147. package/lib/crypto/DeviceList.d.ts +0 -216
  148. package/lib/crypto/DeviceList.d.ts.map +0 -1
  149. package/lib/crypto/DeviceList.js +0 -892
  150. package/lib/crypto/DeviceList.js.map +0 -1
  151. package/lib/crypto/EncryptionSetup.d.ts +0 -152
  152. package/lib/crypto/EncryptionSetup.d.ts.map +0 -1
  153. package/lib/crypto/EncryptionSetup.js +0 -356
  154. package/lib/crypto/EncryptionSetup.js.map +0 -1
  155. package/lib/crypto/OlmDevice.d.ts +0 -457
  156. package/lib/crypto/OlmDevice.d.ts.map +0 -1
  157. package/lib/crypto/OlmDevice.js +0 -1241
  158. package/lib/crypto/OlmDevice.js.map +0 -1
  159. package/lib/crypto/OutgoingRoomKeyRequestManager.d.ts +0 -109
  160. package/lib/crypto/OutgoingRoomKeyRequestManager.d.ts.map +0 -1
  161. package/lib/crypto/OutgoingRoomKeyRequestManager.js +0 -415
  162. package/lib/crypto/OutgoingRoomKeyRequestManager.js.map +0 -1
  163. package/lib/crypto/RoomList.d.ts +0 -26
  164. package/lib/crypto/RoomList.d.ts.map +0 -1
  165. package/lib/crypto/RoomList.js +0 -71
  166. package/lib/crypto/RoomList.js.map +0 -1
  167. package/lib/crypto/SecretSharing.d.ts +0 -24
  168. package/lib/crypto/SecretSharing.d.ts.map +0 -1
  169. package/lib/crypto/SecretSharing.js +0 -194
  170. package/lib/crypto/SecretSharing.js.map +0 -1
  171. package/lib/crypto/SecretStorage.d.ts +0 -55
  172. package/lib/crypto/SecretStorage.d.ts.map +0 -1
  173. package/lib/crypto/SecretStorage.js +0 -118
  174. package/lib/crypto/SecretStorage.js.map +0 -1
  175. package/lib/crypto/aes.d.ts +0 -6
  176. package/lib/crypto/aes.d.ts.map +0 -1
  177. package/lib/crypto/aes.js +0 -24
  178. package/lib/crypto/aes.js.map +0 -1
  179. package/lib/crypto/algorithms/base.d.ts +0 -156
  180. package/lib/crypto/algorithms/base.d.ts.map +0 -1
  181. package/lib/crypto/algorithms/base.js +0 -187
  182. package/lib/crypto/algorithms/base.js.map +0 -1
  183. package/lib/crypto/algorithms/index.d.ts +0 -4
  184. package/lib/crypto/algorithms/index.d.ts.map +0 -1
  185. package/lib/crypto/algorithms/index.js +0 -20
  186. package/lib/crypto/algorithms/index.js.map +0 -1
  187. package/lib/crypto/algorithms/megolm.d.ts +0 -385
  188. package/lib/crypto/algorithms/megolm.d.ts.map +0 -1
  189. package/lib/crypto/algorithms/megolm.js +0 -1822
  190. package/lib/crypto/algorithms/megolm.js.map +0 -1
  191. package/lib/crypto/algorithms/olm.d.ts +0 -5
  192. package/lib/crypto/algorithms/olm.d.ts.map +0 -1
  193. package/lib/crypto/algorithms/olm.js +0 -299
  194. package/lib/crypto/algorithms/olm.js.map +0 -1
  195. package/lib/crypto/api.d.ts +0 -32
  196. package/lib/crypto/api.d.ts.map +0 -1
  197. package/lib/crypto/api.js +0 -22
  198. package/lib/crypto/api.js.map +0 -1
  199. package/lib/crypto/backup.d.ts +0 -227
  200. package/lib/crypto/backup.d.ts.map +0 -1
  201. package/lib/crypto/backup.js +0 -824
  202. package/lib/crypto/backup.js.map +0 -1
  203. package/lib/crypto/crypto.d.ts +0 -3
  204. package/lib/crypto/crypto.d.ts.map +0 -1
  205. package/lib/crypto/crypto.js +0 -19
  206. package/lib/crypto/crypto.js.map +0 -1
  207. package/lib/crypto/dehydration.d.ts +0 -34
  208. package/lib/crypto/dehydration.d.ts.map +0 -1
  209. package/lib/crypto/dehydration.js +0 -252
  210. package/lib/crypto/dehydration.js.map +0 -1
  211. package/lib/crypto/device-converter.d.ts +0 -9
  212. package/lib/crypto/device-converter.d.ts.map +0 -1
  213. package/lib/crypto/device-converter.js +0 -42
  214. package/lib/crypto/device-converter.js.map +0 -1
  215. package/lib/crypto/deviceinfo.d.ts +0 -99
  216. package/lib/crypto/deviceinfo.d.ts.map +0 -1
  217. package/lib/crypto/deviceinfo.js +0 -148
  218. package/lib/crypto/deviceinfo.js.map +0 -1
  219. package/lib/crypto/index.d.ts +0 -1210
  220. package/lib/crypto/index.d.ts.map +0 -1
  221. package/lib/crypto/index.js +0 -4101
  222. package/lib/crypto/index.js.map +0 -1
  223. package/lib/crypto/key_passphrase.d.ts +0 -14
  224. package/lib/crypto/key_passphrase.d.ts.map +0 -1
  225. package/lib/crypto/key_passphrase.js +0 -44
  226. package/lib/crypto/key_passphrase.js.map +0 -1
  227. package/lib/crypto/keybackup.d.ts +0 -18
  228. package/lib/crypto/keybackup.d.ts.map +0 -1
  229. package/lib/crypto/keybackup.js +0 -1
  230. package/lib/crypto/keybackup.js.map +0 -1
  231. package/lib/crypto/olmlib.d.ts +0 -129
  232. package/lib/crypto/olmlib.d.ts.map +0 -1
  233. package/lib/crypto/olmlib.js +0 -492
  234. package/lib/crypto/olmlib.js.map +0 -1
  235. package/lib/crypto/recoverykey.d.ts +0 -2
  236. package/lib/crypto/recoverykey.d.ts.map +0 -1
  237. package/lib/crypto/recoverykey.js +0 -19
  238. package/lib/crypto/recoverykey.js.map +0 -1
  239. package/lib/crypto/store/base.d.ts +0 -252
  240. package/lib/crypto/store/base.d.ts.map +0 -1
  241. package/lib/crypto/store/base.js +0 -64
  242. package/lib/crypto/store/base.js.map +0 -1
  243. package/lib/crypto/store/indexeddb-crypto-store-backend.d.ts +0 -187
  244. package/lib/crypto/store/indexeddb-crypto-store-backend.d.ts.map +0 -1
  245. package/lib/crypto/store/indexeddb-crypto-store-backend.js +0 -1145
  246. package/lib/crypto/store/indexeddb-crypto-store-backend.js.map +0 -1
  247. package/lib/crypto/store/indexeddb-crypto-store.d.ts +0 -432
  248. package/lib/crypto/store/indexeddb-crypto-store.d.ts.map +0 -1
  249. package/lib/crypto/store/indexeddb-crypto-store.js +0 -728
  250. package/lib/crypto/store/indexeddb-crypto-store.js.map +0 -1
  251. package/lib/crypto/store/localStorage-crypto-store.d.ts +0 -119
  252. package/lib/crypto/store/localStorage-crypto-store.d.ts.map +0 -1
  253. package/lib/crypto/store/localStorage-crypto-store.js +0 -531
  254. package/lib/crypto/store/localStorage-crypto-store.js.map +0 -1
  255. package/lib/crypto/store/memory-crypto-store.d.ts +0 -215
  256. package/lib/crypto/store/memory-crypto-store.d.ts.map +0 -1
  257. package/lib/crypto/store/memory-crypto-store.js +0 -622
  258. package/lib/crypto/store/memory-crypto-store.js.map +0 -1
  259. package/lib/crypto/verification/Base.d.ts +0 -105
  260. package/lib/crypto/verification/Base.d.ts.map +0 -1
  261. package/lib/crypto/verification/Base.js +0 -372
  262. package/lib/crypto/verification/Base.js.map +0 -1
  263. package/lib/crypto/verification/Error.d.ts +0 -35
  264. package/lib/crypto/verification/Error.d.ts.map +0 -1
  265. package/lib/crypto/verification/Error.js +0 -86
  266. package/lib/crypto/verification/Error.js.map +0 -1
  267. package/lib/crypto/verification/IllegalMethod.d.ts +0 -15
  268. package/lib/crypto/verification/IllegalMethod.d.ts.map +0 -1
  269. package/lib/crypto/verification/IllegalMethod.js +0 -43
  270. package/lib/crypto/verification/IllegalMethod.js.map +0 -1
  271. package/lib/crypto/verification/QRCode.d.ts +0 -51
  272. package/lib/crypto/verification/QRCode.d.ts.map +0 -1
  273. package/lib/crypto/verification/QRCode.js +0 -277
  274. package/lib/crypto/verification/QRCode.js.map +0 -1
  275. package/lib/crypto/verification/SAS.d.ts +0 -27
  276. package/lib/crypto/verification/SAS.d.ts.map +0 -1
  277. package/lib/crypto/verification/SAS.js +0 -485
  278. package/lib/crypto/verification/SAS.js.map +0 -1
  279. package/lib/crypto/verification/SASDecimal.d.ts +0 -8
  280. package/lib/crypto/verification/SASDecimal.d.ts.map +0 -1
  281. package/lib/crypto/verification/SASDecimal.js +0 -34
  282. package/lib/crypto/verification/SASDecimal.js.map +0 -1
  283. package/lib/crypto/verification/request/Channel.d.ts +0 -18
  284. package/lib/crypto/verification/request/Channel.d.ts.map +0 -1
  285. package/lib/crypto/verification/request/Channel.js +0 -1
  286. package/lib/crypto/verification/request/Channel.js.map +0 -1
  287. package/lib/crypto/verification/request/InRoomChannel.d.ts +0 -113
  288. package/lib/crypto/verification/request/InRoomChannel.d.ts.map +0 -1
  289. package/lib/crypto/verification/request/InRoomChannel.js +0 -351
  290. package/lib/crypto/verification/request/InRoomChannel.js.map +0 -1
  291. package/lib/crypto/verification/request/ToDeviceChannel.d.ts +0 -105
  292. package/lib/crypto/verification/request/ToDeviceChannel.d.ts.map +0 -1
  293. package/lib/crypto/verification/request/ToDeviceChannel.js +0 -328
  294. package/lib/crypto/verification/request/ToDeviceChannel.js.map +0 -1
  295. package/lib/crypto/verification/request/VerificationRequest.d.ts +0 -227
  296. package/lib/crypto/verification/request/VerificationRequest.d.ts.map +0 -1
  297. package/lib/crypto/verification/request/VerificationRequest.js +0 -937
  298. package/lib/crypto/verification/request/VerificationRequest.js.map +0 -1
  299. package/lib/crypto-api/CryptoEvent.d.ts +0 -69
  300. package/lib/crypto-api/CryptoEvent.d.ts.map +0 -1
  301. package/lib/crypto-api/CryptoEvent.js +0 -33
  302. package/lib/crypto-api/CryptoEvent.js.map +0 -1
  303. package/lib/crypto-api/CryptoEventHandlerMap.d.ts +0 -16
  304. package/lib/crypto-api/CryptoEventHandlerMap.d.ts.map +0 -1
  305. package/lib/crypto-api/CryptoEventHandlerMap.js +0 -22
  306. package/lib/crypto-api/CryptoEventHandlerMap.js.map +0 -1
  307. package/lib/crypto-api/index.d.ts +0 -978
  308. package/lib/crypto-api/index.d.ts.map +0 -1
  309. package/lib/crypto-api/index.js +0 -304
  310. package/lib/crypto-api/index.js.map +0 -1
  311. package/lib/crypto-api/key-passphrase.d.ts +0 -11
  312. package/lib/crypto-api/key-passphrase.d.ts.map +0 -1
  313. package/lib/crypto-api/key-passphrase.js +0 -51
  314. package/lib/crypto-api/key-passphrase.js.map +0 -1
  315. package/lib/crypto-api/keybackup.d.ts +0 -88
  316. package/lib/crypto-api/keybackup.d.ts.map +0 -1
  317. package/lib/crypto-api/keybackup.js +0 -1
  318. package/lib/crypto-api/keybackup.js.map +0 -1
  319. package/lib/crypto-api/recovery-key.d.ts +0 -11
  320. package/lib/crypto-api/recovery-key.d.ts.map +0 -1
  321. package/lib/crypto-api/recovery-key.js +0 -65
  322. package/lib/crypto-api/recovery-key.js.map +0 -1
  323. package/lib/crypto-api/verification.d.ts +0 -344
  324. package/lib/crypto-api/verification.d.ts.map +0 -1
  325. package/lib/crypto-api/verification.js +0 -91
  326. package/lib/crypto-api/verification.js.map +0 -1
  327. package/lib/matrixrtc/CallMembership.d.ts +0 -66
  328. package/lib/matrixrtc/CallMembership.d.ts.map +0 -1
  329. package/lib/matrixrtc/CallMembership.js +0 -197
  330. package/lib/matrixrtc/CallMembership.js.map +0 -1
  331. package/lib/matrixrtc/LivekitFocus.d.ts +0 -16
  332. package/lib/matrixrtc/LivekitFocus.d.ts.map +0 -1
  333. package/lib/matrixrtc/LivekitFocus.js +0 -20
  334. package/lib/matrixrtc/LivekitFocus.js.map +0 -1
  335. package/lib/matrixrtc/MatrixRTCSession.d.ts +0 -295
  336. package/lib/matrixrtc/MatrixRTCSession.d.ts.map +0 -1
  337. package/lib/matrixrtc/MatrixRTCSession.js +0 -1043
  338. package/lib/matrixrtc/MatrixRTCSession.js.map +0 -1
  339. package/lib/matrixrtc/MatrixRTCSessionManager.d.ts +0 -40
  340. package/lib/matrixrtc/MatrixRTCSessionManager.d.ts.map +0 -1
  341. package/lib/matrixrtc/MatrixRTCSessionManager.js +0 -146
  342. package/lib/matrixrtc/MatrixRTCSessionManager.js.map +0 -1
  343. package/lib/matrixrtc/focus.d.ts +0 -10
  344. package/lib/matrixrtc/focus.d.ts.map +0 -1
  345. package/lib/matrixrtc/focus.js +0 -1
  346. package/lib/matrixrtc/focus.js.map +0 -1
  347. package/lib/matrixrtc/index.d.ts +0 -7
  348. package/lib/matrixrtc/index.d.ts.map +0 -1
  349. package/lib/matrixrtc/index.js +0 -21
  350. package/lib/matrixrtc/index.js.map +0 -1
  351. package/lib/matrixrtc/types.d.ts +0 -19
  352. package/lib/matrixrtc/types.d.ts.map +0 -1
  353. package/lib/matrixrtc/types.js +0 -1
  354. package/lib/matrixrtc/types.js.map +0 -1
  355. package/lib/rendezvous/MSC4108SignInWithQR.d.ts +0 -112
  356. package/lib/rendezvous/MSC4108SignInWithQR.d.ts.map +0 -1
  357. package/lib/rendezvous/MSC4108SignInWithQR.js +0 -392
  358. package/lib/rendezvous/MSC4108SignInWithQR.js.map +0 -1
  359. package/lib/rendezvous/RendezvousChannel.d.ts +0 -27
  360. package/lib/rendezvous/RendezvousChannel.d.ts.map +0 -1
  361. package/lib/rendezvous/RendezvousChannel.js +0 -1
  362. package/lib/rendezvous/RendezvousChannel.js.map +0 -1
  363. package/lib/rendezvous/RendezvousCode.d.ts +0 -9
  364. package/lib/rendezvous/RendezvousCode.d.ts.map +0 -1
  365. package/lib/rendezvous/RendezvousCode.js +0 -1
  366. package/lib/rendezvous/RendezvousCode.js.map +0 -1
  367. package/lib/rendezvous/RendezvousError.d.ts +0 -6
  368. package/lib/rendezvous/RendezvousError.d.ts.map +0 -1
  369. package/lib/rendezvous/RendezvousError.js +0 -23
  370. package/lib/rendezvous/RendezvousError.js.map +0 -1
  371. package/lib/rendezvous/RendezvousFailureReason.d.ts +0 -31
  372. package/lib/rendezvous/RendezvousFailureReason.d.ts.map +0 -1
  373. package/lib/rendezvous/RendezvousFailureReason.js +0 -38
  374. package/lib/rendezvous/RendezvousFailureReason.js.map +0 -1
  375. package/lib/rendezvous/RendezvousIntent.d.ts +0 -5
  376. package/lib/rendezvous/RendezvousIntent.d.ts.map +0 -1
  377. package/lib/rendezvous/RendezvousIntent.js +0 -22
  378. package/lib/rendezvous/RendezvousIntent.js.map +0 -1
  379. package/lib/rendezvous/RendezvousTransport.d.ts +0 -36
  380. package/lib/rendezvous/RendezvousTransport.d.ts.map +0 -1
  381. package/lib/rendezvous/RendezvousTransport.js +0 -1
  382. package/lib/rendezvous/RendezvousTransport.js.map +0 -1
  383. package/lib/rendezvous/channels/MSC4108SecureChannel.d.ts +0 -58
  384. package/lib/rendezvous/channels/MSC4108SecureChannel.d.ts.map +0 -1
  385. package/lib/rendezvous/channels/MSC4108SecureChannel.js +0 -246
  386. package/lib/rendezvous/channels/MSC4108SecureChannel.js.map +0 -1
  387. package/lib/rendezvous/channels/index.d.ts +0 -2
  388. package/lib/rendezvous/channels/index.d.ts.map +0 -1
  389. package/lib/rendezvous/channels/index.js +0 -18
  390. package/lib/rendezvous/channels/index.js.map +0 -1
  391. package/lib/rendezvous/index.d.ts +0 -10
  392. package/lib/rendezvous/index.d.ts.map +0 -1
  393. package/lib/rendezvous/index.js +0 -23
  394. package/lib/rendezvous/index.js.map +0 -1
  395. package/lib/rendezvous/transports/MSC4108RendezvousSession.d.ts +0 -61
  396. package/lib/rendezvous/transports/MSC4108RendezvousSession.d.ts.map +0 -1
  397. package/lib/rendezvous/transports/MSC4108RendezvousSession.js +0 -253
  398. package/lib/rendezvous/transports/MSC4108RendezvousSession.js.map +0 -1
  399. package/lib/rendezvous/transports/index.d.ts +0 -2
  400. package/lib/rendezvous/transports/index.d.ts.map +0 -1
  401. package/lib/rendezvous/transports/index.js +0 -18
  402. package/lib/rendezvous/transports/index.js.map +0 -1
  403. package/lib/rust-crypto/CrossSigningIdentity.d.ts +0 -33
  404. package/lib/rust-crypto/CrossSigningIdentity.d.ts.map +0 -1
  405. package/lib/rust-crypto/CrossSigningIdentity.js +0 -157
  406. package/lib/rust-crypto/CrossSigningIdentity.js.map +0 -1
  407. package/lib/rust-crypto/DehydratedDeviceManager.d.ts +0 -98
  408. package/lib/rust-crypto/DehydratedDeviceManager.d.ts.map +0 -1
  409. package/lib/rust-crypto/DehydratedDeviceManager.js +0 -285
  410. package/lib/rust-crypto/DehydratedDeviceManager.js.map +0 -1
  411. package/lib/rust-crypto/KeyClaimManager.d.ts +0 -33
  412. package/lib/rust-crypto/KeyClaimManager.d.ts.map +0 -1
  413. package/lib/rust-crypto/KeyClaimManager.js +0 -82
  414. package/lib/rust-crypto/KeyClaimManager.js.map +0 -1
  415. package/lib/rust-crypto/OutgoingRequestProcessor.d.ts +0 -43
  416. package/lib/rust-crypto/OutgoingRequestProcessor.d.ts.map +0 -1
  417. package/lib/rust-crypto/OutgoingRequestProcessor.js +0 -195
  418. package/lib/rust-crypto/OutgoingRequestProcessor.js.map +0 -1
  419. package/lib/rust-crypto/OutgoingRequestsManager.d.ts +0 -47
  420. package/lib/rust-crypto/OutgoingRequestsManager.d.ts.map +0 -1
  421. package/lib/rust-crypto/OutgoingRequestsManager.js +0 -148
  422. package/lib/rust-crypto/OutgoingRequestsManager.js.map +0 -1
  423. package/lib/rust-crypto/PerSessionKeyBackupDownloader.d.ts +0 -120
  424. package/lib/rust-crypto/PerSessionKeyBackupDownloader.d.ts.map +0 -1
  425. package/lib/rust-crypto/PerSessionKeyBackupDownloader.js +0 -467
  426. package/lib/rust-crypto/PerSessionKeyBackupDownloader.js.map +0 -1
  427. package/lib/rust-crypto/RoomEncryptor.d.ts +0 -98
  428. package/lib/rust-crypto/RoomEncryptor.d.ts.map +0 -1
  429. package/lib/rust-crypto/RoomEncryptor.js +0 -299
  430. package/lib/rust-crypto/RoomEncryptor.js.map +0 -1
  431. package/lib/rust-crypto/backup.d.ts +0 -254
  432. package/lib/rust-crypto/backup.d.ts.map +0 -1
  433. package/lib/rust-crypto/backup.js +0 -837
  434. package/lib/rust-crypto/backup.js.map +0 -1
  435. package/lib/rust-crypto/constants.d.ts +0 -3
  436. package/lib/rust-crypto/constants.d.ts.map +0 -1
  437. package/lib/rust-crypto/constants.js +0 -19
  438. package/lib/rust-crypto/constants.js.map +0 -1
  439. package/lib/rust-crypto/device-converter.d.ts +0 -28
  440. package/lib/rust-crypto/device-converter.d.ts.map +0 -1
  441. package/lib/rust-crypto/device-converter.js +0 -123
  442. package/lib/rust-crypto/device-converter.js.map +0 -1
  443. package/lib/rust-crypto/index.d.ts +0 -61
  444. package/lib/rust-crypto/index.d.ts.map +0 -1
  445. package/lib/rust-crypto/index.js +0 -152
  446. package/lib/rust-crypto/index.js.map +0 -1
  447. package/lib/rust-crypto/libolm_migration.d.ts +0 -81
  448. package/lib/rust-crypto/libolm_migration.d.ts.map +0 -1
  449. package/lib/rust-crypto/libolm_migration.js +0 -459
  450. package/lib/rust-crypto/libolm_migration.js.map +0 -1
  451. package/lib/rust-crypto/rust-crypto.d.ts +0 -556
  452. package/lib/rust-crypto/rust-crypto.d.ts.map +0 -1
  453. package/lib/rust-crypto/rust-crypto.js +0 -2016
  454. package/lib/rust-crypto/rust-crypto.js.map +0 -1
  455. package/lib/rust-crypto/secret-storage.d.ts +0 -22
  456. package/lib/rust-crypto/secret-storage.d.ts.map +0 -1
  457. package/lib/rust-crypto/secret-storage.js +0 -63
  458. package/lib/rust-crypto/secret-storage.js.map +0 -1
  459. package/lib/rust-crypto/verification.d.ts +0 -319
  460. package/lib/rust-crypto/verification.d.ts.map +0 -1
  461. package/lib/rust-crypto/verification.js +0 -816
  462. package/lib/rust-crypto/verification.js.map +0 -1
  463. package/lib/secret-storage.d.ts +0 -370
  464. package/lib/secret-storage.d.ts.map +0 -1
  465. package/lib/secret-storage.js +0 -466
  466. package/lib/secret-storage.js.map +0 -1
  467. package/lib/utils/decryptAESSecretStorageItem.d.ts +0 -12
  468. package/lib/utils/decryptAESSecretStorageItem.d.ts.map +0 -1
  469. package/lib/utils/decryptAESSecretStorageItem.js +0 -50
  470. package/lib/utils/decryptAESSecretStorageItem.js.map +0 -1
  471. package/lib/utils/encryptAESSecretStorageItem.d.ts +0 -16
  472. package/lib/utils/encryptAESSecretStorageItem.d.ts.map +0 -1
  473. package/lib/utils/encryptAESSecretStorageItem.js +0 -68
  474. package/lib/utils/encryptAESSecretStorageItem.js.map +0 -1
  475. package/lib/utils/internal/deriveKeys.d.ts +0 -10
  476. package/lib/utils/internal/deriveKeys.d.ts.map +0 -1
  477. package/lib/utils/internal/deriveKeys.js +0 -60
  478. package/lib/utils/internal/deriveKeys.js.map +0 -1
  479. package/lib/webrtc/audioContext.d.ts +0 -15
  480. package/lib/webrtc/audioContext.d.ts.map +0 -1
  481. package/lib/webrtc/audioContext.js +0 -46
  482. package/lib/webrtc/audioContext.js.map +0 -1
  483. package/lib/webrtc/call.d.ts +0 -560
  484. package/lib/webrtc/call.d.ts.map +0 -1
  485. package/lib/webrtc/call.js +0 -2541
  486. package/lib/webrtc/call.js.map +0 -1
  487. package/lib/webrtc/callEventHandler.d.ts +0 -37
  488. package/lib/webrtc/callEventHandler.d.ts.map +0 -1
  489. package/lib/webrtc/callEventHandler.js +0 -344
  490. package/lib/webrtc/callEventHandler.js.map +0 -1
  491. package/lib/webrtc/callEventTypes.d.ts +0 -73
  492. package/lib/webrtc/callEventTypes.d.ts.map +0 -1
  493. package/lib/webrtc/callEventTypes.js +0 -13
  494. package/lib/webrtc/callEventTypes.js.map +0 -1
  495. package/lib/webrtc/callFeed.d.ts +0 -128
  496. package/lib/webrtc/callFeed.d.ts.map +0 -1
  497. package/lib/webrtc/callFeed.js +0 -289
  498. package/lib/webrtc/callFeed.js.map +0 -1
  499. package/lib/webrtc/groupCall.d.ts +0 -323
  500. package/lib/webrtc/groupCall.d.ts.map +0 -1
  501. package/lib/webrtc/groupCall.js +0 -1337
  502. package/lib/webrtc/groupCall.js.map +0 -1
  503. package/lib/webrtc/groupCallEventHandler.d.ts +0 -31
  504. package/lib/webrtc/groupCallEventHandler.d.ts.map +0 -1
  505. package/lib/webrtc/groupCallEventHandler.js +0 -178
  506. package/lib/webrtc/groupCallEventHandler.js.map +0 -1
  507. package/lib/webrtc/mediaHandler.d.ts +0 -89
  508. package/lib/webrtc/mediaHandler.d.ts.map +0 -1
  509. package/lib/webrtc/mediaHandler.js +0 -437
  510. package/lib/webrtc/mediaHandler.js.map +0 -1
  511. package/lib/webrtc/stats/callFeedStatsReporter.d.ts +0 -8
  512. package/lib/webrtc/stats/callFeedStatsReporter.d.ts.map +0 -1
  513. package/lib/webrtc/stats/callFeedStatsReporter.js +0 -82
  514. package/lib/webrtc/stats/callFeedStatsReporter.js.map +0 -1
  515. package/lib/webrtc/stats/callStatsReportGatherer.d.ts +0 -25
  516. package/lib/webrtc/stats/callStatsReportGatherer.d.ts.map +0 -1
  517. package/lib/webrtc/stats/callStatsReportGatherer.js +0 -199
  518. package/lib/webrtc/stats/callStatsReportGatherer.js.map +0 -1
  519. package/lib/webrtc/stats/callStatsReportSummary.d.ts +0 -17
  520. package/lib/webrtc/stats/callStatsReportSummary.d.ts.map +0 -1
  521. package/lib/webrtc/stats/callStatsReportSummary.js +0 -1
  522. package/lib/webrtc/stats/callStatsReportSummary.js.map +0 -1
  523. package/lib/webrtc/stats/connectionStats.d.ts +0 -28
  524. package/lib/webrtc/stats/connectionStats.d.ts.map +0 -1
  525. package/lib/webrtc/stats/connectionStats.js +0 -26
  526. package/lib/webrtc/stats/connectionStats.js.map +0 -1
  527. package/lib/webrtc/stats/connectionStatsBuilder.d.ts +0 -5
  528. package/lib/webrtc/stats/connectionStatsBuilder.d.ts.map +0 -1
  529. package/lib/webrtc/stats/connectionStatsBuilder.js +0 -27
  530. package/lib/webrtc/stats/connectionStatsBuilder.js.map +0 -1
  531. package/lib/webrtc/stats/connectionStatsReportBuilder.d.ts +0 -7
  532. package/lib/webrtc/stats/connectionStatsReportBuilder.d.ts.map +0 -1
  533. package/lib/webrtc/stats/connectionStatsReportBuilder.js +0 -121
  534. package/lib/webrtc/stats/connectionStatsReportBuilder.js.map +0 -1
  535. package/lib/webrtc/stats/groupCallStats.d.ts +0 -22
  536. package/lib/webrtc/stats/groupCallStats.d.ts.map +0 -1
  537. package/lib/webrtc/stats/groupCallStats.js +0 -78
  538. package/lib/webrtc/stats/groupCallStats.js.map +0 -1
  539. package/lib/webrtc/stats/media/mediaSsrcHandler.d.ts +0 -10
  540. package/lib/webrtc/stats/media/mediaSsrcHandler.d.ts.map +0 -1
  541. package/lib/webrtc/stats/media/mediaSsrcHandler.js +0 -57
  542. package/lib/webrtc/stats/media/mediaSsrcHandler.js.map +0 -1
  543. package/lib/webrtc/stats/media/mediaTrackHandler.d.ts +0 -12
  544. package/lib/webrtc/stats/media/mediaTrackHandler.d.ts.map +0 -1
  545. package/lib/webrtc/stats/media/mediaTrackHandler.js +0 -62
  546. package/lib/webrtc/stats/media/mediaTrackHandler.js.map +0 -1
  547. package/lib/webrtc/stats/media/mediaTrackStats.d.ts +0 -86
  548. package/lib/webrtc/stats/media/mediaTrackStats.d.ts.map +0 -1
  549. package/lib/webrtc/stats/media/mediaTrackStats.js +0 -142
  550. package/lib/webrtc/stats/media/mediaTrackStats.js.map +0 -1
  551. package/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts +0 -22
  552. package/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts.map +0 -1
  553. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js +0 -76
  554. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map +0 -1
  555. package/lib/webrtc/stats/statsReport.d.ts +0 -99
  556. package/lib/webrtc/stats/statsReport.d.ts.map +0 -1
  557. package/lib/webrtc/stats/statsReport.js +0 -32
  558. package/lib/webrtc/stats/statsReport.js.map +0 -1
  559. package/lib/webrtc/stats/statsReportEmitter.d.ts +0 -15
  560. package/lib/webrtc/stats/statsReportEmitter.d.ts.map +0 -1
  561. package/lib/webrtc/stats/statsReportEmitter.js +0 -33
  562. package/lib/webrtc/stats/statsReportEmitter.js.map +0 -1
  563. package/lib/webrtc/stats/summaryStatsReportGatherer.d.ts +0 -16
  564. package/lib/webrtc/stats/summaryStatsReportGatherer.d.ts.map +0 -1
  565. package/lib/webrtc/stats/summaryStatsReportGatherer.js +0 -116
  566. package/lib/webrtc/stats/summaryStatsReportGatherer.js.map +0 -1
  567. package/lib/webrtc/stats/trackStatsBuilder.d.ts +0 -19
  568. package/lib/webrtc/stats/trackStatsBuilder.d.ts.map +0 -1
  569. package/lib/webrtc/stats/trackStatsBuilder.js +0 -168
  570. package/lib/webrtc/stats/trackStatsBuilder.js.map +0 -1
  571. package/lib/webrtc/stats/transportStats.d.ts +0 -11
  572. package/lib/webrtc/stats/transportStats.d.ts.map +0 -1
  573. package/lib/webrtc/stats/transportStats.js +0 -1
  574. package/lib/webrtc/stats/transportStats.js.map +0 -1
  575. package/lib/webrtc/stats/transportStatsBuilder.d.ts +0 -5
  576. package/lib/webrtc/stats/transportStatsBuilder.d.ts.map +0 -1
  577. package/lib/webrtc/stats/transportStatsBuilder.js +0 -34
  578. package/lib/webrtc/stats/transportStatsBuilder.js.map +0 -1
  579. package/lib/webrtc/stats/valueFormatter.d.ts +0 -4
  580. package/lib/webrtc/stats/valueFormatter.d.ts.map +0 -1
  581. package/lib/webrtc/stats/valueFormatter.js +0 -25
  582. package/lib/webrtc/stats/valueFormatter.js.map +0 -1
  583. package/src/@types/AESEncryptedSecretStoragePayload.ts +0 -29
  584. package/src/@types/crypto.ts +0 -73
  585. package/src/@types/matrix-sdk-crypto-wasm.d.ts +0 -44
  586. package/src/common-crypto/CryptoBackend.ts +0 -302
  587. package/src/common-crypto/README.md +0 -4
  588. package/src/common-crypto/key-passphrase.ts +0 -43
  589. package/src/crypto/CrossSigning.ts +0 -773
  590. package/src/crypto/DeviceList.ts +0 -989
  591. package/src/crypto/EncryptionSetup.ts +0 -351
  592. package/src/crypto/OlmDevice.ts +0 -1500
  593. package/src/crypto/OutgoingRoomKeyRequestManager.ts +0 -485
  594. package/src/crypto/RoomList.ts +0 -70
  595. package/src/crypto/SecretSharing.ts +0 -240
  596. package/src/crypto/SecretStorage.ts +0 -136
  597. package/src/crypto/aes.ts +0 -23
  598. package/src/crypto/algorithms/base.ts +0 -236
  599. package/src/crypto/algorithms/index.ts +0 -20
  600. package/src/crypto/algorithms/megolm.ts +0 -2216
  601. package/src/crypto/algorithms/olm.ts +0 -381
  602. package/src/crypto/api.ts +0 -70
  603. package/src/crypto/backup.ts +0 -922
  604. package/src/crypto/crypto.ts +0 -18
  605. package/src/crypto/dehydration.ts +0 -272
  606. package/src/crypto/device-converter.ts +0 -45
  607. package/src/crypto/deviceinfo.ts +0 -158
  608. package/src/crypto/index.ts +0 -4418
  609. package/src/crypto/key_passphrase.ts +0 -42
  610. package/src/crypto/keybackup.ts +0 -47
  611. package/src/crypto/olmlib.ts +0 -539
  612. package/src/crypto/recoverykey.ts +0 -18
  613. package/src/crypto/store/base.ts +0 -348
  614. package/src/crypto/store/indexeddb-crypto-store-backend.ts +0 -1250
  615. package/src/crypto/store/indexeddb-crypto-store.ts +0 -845
  616. package/src/crypto/store/localStorage-crypto-store.ts +0 -579
  617. package/src/crypto/store/memory-crypto-store.ts +0 -680
  618. package/src/crypto/verification/Base.ts +0 -409
  619. package/src/crypto/verification/Error.ts +0 -76
  620. package/src/crypto/verification/IllegalMethod.ts +0 -50
  621. package/src/crypto/verification/QRCode.ts +0 -310
  622. package/src/crypto/verification/SAS.ts +0 -494
  623. package/src/crypto/verification/SASDecimal.ts +0 -37
  624. package/src/crypto/verification/request/Channel.ts +0 -34
  625. package/src/crypto/verification/request/InRoomChannel.ts +0 -371
  626. package/src/crypto/verification/request/ToDeviceChannel.ts +0 -354
  627. package/src/crypto/verification/request/VerificationRequest.ts +0 -976
  628. package/src/crypto-api/CryptoEvent.ts +0 -93
  629. package/src/crypto-api/CryptoEventHandlerMap.ts +0 -32
  630. package/src/crypto-api/index.ts +0 -1175
  631. package/src/crypto-api/key-passphrase.ts +0 -58
  632. package/src/crypto-api/keybackup.ts +0 -115
  633. package/src/crypto-api/recovery-key.ts +0 -69
  634. package/src/crypto-api/verification.ts +0 -408
  635. package/src/matrixrtc/CallMembership.ts +0 -247
  636. package/src/matrixrtc/LivekitFocus.ts +0 -39
  637. package/src/matrixrtc/MatrixRTCSession.ts +0 -1319
  638. package/src/matrixrtc/MatrixRTCSessionManager.ts +0 -166
  639. package/src/matrixrtc/focus.ts +0 -25
  640. package/src/matrixrtc/index.ts +0 -22
  641. package/src/matrixrtc/types.ts +0 -36
  642. package/src/rendezvous/MSC4108SignInWithQR.ts +0 -444
  643. package/src/rendezvous/RendezvousChannel.ts +0 -48
  644. package/src/rendezvous/RendezvousCode.ts +0 -25
  645. package/src/rendezvous/RendezvousError.ts +0 -26
  646. package/src/rendezvous/RendezvousFailureReason.ts +0 -49
  647. package/src/rendezvous/RendezvousIntent.ts +0 -20
  648. package/src/rendezvous/RendezvousTransport.ts +0 -58
  649. package/src/rendezvous/channels/MSC4108SecureChannel.ts +0 -270
  650. package/src/rendezvous/channels/index.ts +0 -17
  651. package/src/rendezvous/index.ts +0 -25
  652. package/src/rendezvous/transports/MSC4108RendezvousSession.ts +0 -270
  653. package/src/rendezvous/transports/index.ts +0 -17
  654. package/src/rust-crypto/CrossSigningIdentity.ts +0 -183
  655. package/src/rust-crypto/DehydratedDeviceManager.ts +0 -306
  656. package/src/rust-crypto/KeyClaimManager.ts +0 -86
  657. package/src/rust-crypto/OutgoingRequestProcessor.ts +0 -236
  658. package/src/rust-crypto/OutgoingRequestsManager.ts +0 -143
  659. package/src/rust-crypto/PerSessionKeyBackupDownloader.ts +0 -501
  660. package/src/rust-crypto/RoomEncryptor.ts +0 -352
  661. package/src/rust-crypto/backup.ts +0 -881
  662. package/src/rust-crypto/constants.ts +0 -18
  663. package/src/rust-crypto/device-converter.ts +0 -128
  664. package/src/rust-crypto/index.ts +0 -237
  665. package/src/rust-crypto/libolm_migration.ts +0 -530
  666. package/src/rust-crypto/rust-crypto.ts +0 -2205
  667. package/src/rust-crypto/secret-storage.ts +0 -60
  668. package/src/rust-crypto/verification.ts +0 -830
  669. package/src/secret-storage.ts +0 -693
  670. package/src/utils/decryptAESSecretStorageItem.ts +0 -54
  671. package/src/utils/encryptAESSecretStorageItem.ts +0 -73
  672. package/src/utils/internal/deriveKeys.ts +0 -63
  673. package/src/webrtc/audioContext.ts +0 -44
  674. package/src/webrtc/call.ts +0 -3074
  675. package/src/webrtc/callEventHandler.ts +0 -425
  676. package/src/webrtc/callEventTypes.ts +0 -93
  677. package/src/webrtc/callFeed.ts +0 -364
  678. package/src/webrtc/groupCall.ts +0 -1735
  679. package/src/webrtc/groupCallEventHandler.ts +0 -234
  680. package/src/webrtc/mediaHandler.ts +0 -484
  681. package/src/webrtc/stats/callFeedStatsReporter.ts +0 -94
  682. package/src/webrtc/stats/callStatsReportGatherer.ts +0 -219
  683. package/src/webrtc/stats/callStatsReportSummary.ts +0 -30
  684. package/src/webrtc/stats/connectionStats.ts +0 -47
  685. package/src/webrtc/stats/connectionStatsBuilder.ts +0 -28
  686. package/src/webrtc/stats/connectionStatsReportBuilder.ts +0 -140
  687. package/src/webrtc/stats/groupCallStats.ts +0 -93
  688. package/src/webrtc/stats/media/mediaSsrcHandler.ts +0 -57
  689. package/src/webrtc/stats/media/mediaTrackHandler.ts +0 -76
  690. package/src/webrtc/stats/media/mediaTrackStats.ts +0 -176
  691. package/src/webrtc/stats/media/mediaTrackStatsHandler.ts +0 -90
  692. package/src/webrtc/stats/statsReport.ts +0 -133
  693. package/src/webrtc/stats/statsReportEmitter.ts +0 -49
  694. package/src/webrtc/stats/summaryStatsReportGatherer.ts +0 -148
  695. package/src/webrtc/stats/trackStatsBuilder.ts +0 -207
  696. package/src/webrtc/stats/transportStats.ts +0 -26
  697. package/src/webrtc/stats/transportStatsBuilder.ts +0 -48
  698. package/src/webrtc/stats/valueFormatter.ts +0 -27
@@ -1,816 +0,0 @@
1
- import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
- import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
- /*
4
- Copyright 2023 The Matrix.org Foundation C.I.C.
5
-
6
- Licensed under the Apache License, Version 2.0 (the "License");
7
- you may not use this file except in compliance with the License.
8
- You may obtain a copy of the License at
9
-
10
- http://www.apache.org/licenses/LICENSE-2.0
11
-
12
- Unless required by applicable law or agreed to in writing, software
13
- distributed under the License is distributed on an "AS IS" BASIS,
14
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- See the License for the specific language governing permissions and
16
- limitations under the License.
17
- */
18
-
19
- import * as RustSdkCryptoJs from "@matrix-org/matrix-sdk-crypto-wasm";
20
- import { QrState } from "@matrix-org/matrix-sdk-crypto-wasm";
21
- import { VerificationPhase, VerificationRequestEvent, VerifierEvent } from "../crypto-api/verification.js";
22
- import { TypedEventEmitter } from "../models/typed-event-emitter.js";
23
- import { TypedReEmitter } from "../ReEmitter.js";
24
- import { EventType, MsgType } from "../@types/event.js";
25
- import { defer } from "../utils.js";
26
- import { VerificationMethod } from "../types.js";
27
-
28
- /**
29
- * An incoming, or outgoing, request to verify a user or a device via cross-signing.
30
- *
31
- * @internal
32
- */
33
- export class RustVerificationRequest extends TypedEventEmitter {
34
- /**
35
- * Construct a new RustVerificationRequest to wrap the rust-level `VerificationRequest`.
36
- *
37
- * @param olmMachine - The `OlmMachine` from the underlying rust crypto sdk.
38
- * @param inner - VerificationRequest from the Rust SDK.
39
- * @param outgoingRequestProcessor - `OutgoingRequestProcessor` to use for making outgoing HTTP requests.
40
- * @param supportedVerificationMethods - Verification methods to use when `accept()` is called.
41
- */
42
- constructor(olmMachine, inner, outgoingRequestProcessor, supportedVerificationMethods) {
43
- super();
44
- this.olmMachine = olmMachine;
45
- this.inner = inner;
46
- this.outgoingRequestProcessor = outgoingRequestProcessor;
47
- this.supportedVerificationMethods = supportedVerificationMethods;
48
- /** a reëmitter which relays VerificationRequestEvent.Changed events emitted by the verifier */
49
- _defineProperty(this, "reEmitter", void 0);
50
- /** Are we in the process of sending an `m.key.verification.ready` event? */
51
- _defineProperty(this, "_accepting", false);
52
- /** Are we in the process of sending an `m.key.verification.cancellation` event? */
53
- _defineProperty(this, "_cancelling", false);
54
- _defineProperty(this, "_verifier", void 0);
55
- this.reEmitter = new TypedReEmitter(this);
56
-
57
- // Obviously, the Rust object maintains a reference to the callback function. If the callback function maintains
58
- // a reference to the Rust object, then we have a reference cycle which means that `RustVerificationRequest`
59
- // will never be garbage-collected, and hence the underlying rust object will never be freed.
60
- //
61
- // To avoid this reference cycle, use a weak reference in the callback function. If the `RustVerificationRequest`
62
- // gets garbage-collected, then there is nothing to update!
63
- var weakThis = new WeakRef(this);
64
- inner.registerChangesCallback(/*#__PURE__*/_asyncToGenerator(function* () {
65
- var _weakThis$deref;
66
- return (_weakThis$deref = weakThis.deref()) === null || _weakThis$deref === void 0 ? void 0 : _weakThis$deref.onChange();
67
- }));
68
- }
69
-
70
- /**
71
- * Hook which is called when the underlying rust class notifies us that there has been a change.
72
- */
73
- onChange() {
74
- var verification = this.inner.getVerification();
75
-
76
- // Set the _verifier object (wrapping the rust `Verification` as a js-sdk Verifier) if:
77
- // - we now have a `Verification` where we lacked one before
78
- // - we have transitioned from QR to SAS
79
- // - we are verifying with SAS, but we need to replace our verifier with a new one because both parties
80
- // tried to start verification at the same time, and we lost the tie breaking
81
- if (verification instanceof RustSdkCryptoJs.Sas) {
82
- if (this._verifier === undefined || this._verifier instanceof RustQrCodeVerifier) {
83
- this.setVerifier(new RustSASVerifier(verification, this, this.outgoingRequestProcessor));
84
- } else if (this._verifier instanceof RustSASVerifier) {
85
- this._verifier.replaceInner(verification);
86
- }
87
- } else if (verification instanceof RustSdkCryptoJs.Qr && this._verifier === undefined) {
88
- this.setVerifier(new RustQrCodeVerifier(verification, this.outgoingRequestProcessor));
89
- }
90
- this.emit(VerificationRequestEvent.Change);
91
- }
92
- setVerifier(verifier) {
93
- // if we already have a verifier, unsubscribe from its events
94
- if (this._verifier) {
95
- this.reEmitter.stopReEmitting(this._verifier, [VerificationRequestEvent.Change]);
96
- }
97
- this._verifier = verifier;
98
- this.reEmitter.reEmit(this._verifier, [VerificationRequestEvent.Change]);
99
- }
100
-
101
- /**
102
- * Unique ID for this verification request.
103
- *
104
- * An ID isn't assigned until the first message is sent, so this may be `undefined` in the early phases.
105
- */
106
- get transactionId() {
107
- return this.inner.flowId;
108
- }
109
-
110
- /**
111
- * For an in-room verification, the ID of the room.
112
- *
113
- * For to-device verifications, `undefined`.
114
- */
115
- get roomId() {
116
- var _this$inner$roomId;
117
- return (_this$inner$roomId = this.inner.roomId) === null || _this$inner$roomId === void 0 ? void 0 : _this$inner$roomId.toString();
118
- }
119
-
120
- /**
121
- * True if this request was initiated by the local client.
122
- *
123
- * For in-room verifications, the initiator is who sent the `m.key.verification.request` event.
124
- * For to-device verifications, the initiator is who sent the `m.key.verification.start` event.
125
- */
126
- get initiatedByMe() {
127
- return this.inner.weStarted();
128
- }
129
-
130
- /** The user id of the other party in this request */
131
- get otherUserId() {
132
- return this.inner.otherUserId.toString();
133
- }
134
-
135
- /** For verifications via to-device messages: the ID of the other device. Otherwise, undefined. */
136
- get otherDeviceId() {
137
- var _this$inner$otherDevi;
138
- return (_this$inner$otherDevi = this.inner.otherDeviceId) === null || _this$inner$otherDevi === void 0 ? void 0 : _this$inner$otherDevi.toString();
139
- }
140
-
141
- /** Get the other device involved in the verification, if it is known */
142
- getOtherDevice() {
143
- var _this = this;
144
- return _asyncToGenerator(function* () {
145
- var otherDeviceId = _this.inner.otherDeviceId;
146
- if (!otherDeviceId) {
147
- return undefined;
148
- }
149
- return yield _this.olmMachine.getDevice(_this.inner.otherUserId, otherDeviceId, 5);
150
- })();
151
- }
152
-
153
- /** True if the other party in this request is one of this user's own devices. */
154
- get isSelfVerification() {
155
- return this.inner.isSelfVerification();
156
- }
157
-
158
- /** current phase of the request. */
159
- get phase() {
160
- var phase = this.inner.phase();
161
- switch (phase) {
162
- case RustSdkCryptoJs.VerificationRequestPhase.Created:
163
- case RustSdkCryptoJs.VerificationRequestPhase.Requested:
164
- return VerificationPhase.Requested;
165
- case RustSdkCryptoJs.VerificationRequestPhase.Ready:
166
- // if we're still sending the `m.key.verification.ready`, that counts as "Requested" in the js-sdk's
167
- // parlance.
168
- return this._accepting ? VerificationPhase.Requested : VerificationPhase.Ready;
169
- case RustSdkCryptoJs.VerificationRequestPhase.Transitioned:
170
- if (!this._verifier) {
171
- // this shouldn't happen, because the onChange handler should have created a _verifier.
172
- throw new Error("VerificationRequest: inner phase == Transitioned but no verifier!");
173
- }
174
- return this._verifier.verificationPhase;
175
- case RustSdkCryptoJs.VerificationRequestPhase.Done:
176
- return VerificationPhase.Done;
177
- case RustSdkCryptoJs.VerificationRequestPhase.Cancelled:
178
- return VerificationPhase.Cancelled;
179
- }
180
- throw new Error("Unknown verification phase ".concat(phase));
181
- }
182
-
183
- /** True if the request has sent its initial event and needs more events to complete
184
- * (ie it is in phase `Requested`, `Ready` or `Started`).
185
- */
186
- get pending() {
187
- if (this.inner.isPassive()) return false;
188
- var phase = this.phase;
189
- return phase !== VerificationPhase.Done && phase !== VerificationPhase.Cancelled;
190
- }
191
-
192
- /**
193
- * True if we have started the process of sending an `m.key.verification.ready` (but have not necessarily received
194
- * the remote echo which causes a transition to {@link VerificationPhase.Ready}.
195
- */
196
- get accepting() {
197
- return this._accepting;
198
- }
199
-
200
- /**
201
- * True if we have started the process of sending an `m.key.verification.cancel` (but have not necessarily received
202
- * the remote echo which causes a transition to {@link VerificationPhase.Cancelled}).
203
- */
204
- get declining() {
205
- return this._cancelling;
206
- }
207
-
208
- /**
209
- * The remaining number of ms before the request will be automatically cancelled.
210
- *
211
- * `null` indicates that there is no timeout
212
- */
213
- get timeout() {
214
- return this.inner.timeRemainingMillis();
215
- }
216
-
217
- /** once the phase is Started (and !initiatedByMe) or Ready: common methods supported by both sides */
218
- get methods() {
219
- throw new Error("not implemented");
220
- }
221
-
222
- /** the method picked in the .start event */
223
- get chosenMethod() {
224
- if (this.phase !== VerificationPhase.Started) return null;
225
- var verification = this.inner.getVerification();
226
- if (verification instanceof RustSdkCryptoJs.Sas) {
227
- return VerificationMethod.Sas;
228
- } else if (verification instanceof RustSdkCryptoJs.Qr) {
229
- return VerificationMethod.Reciprocate;
230
- } else {
231
- return null;
232
- }
233
- }
234
-
235
- /**
236
- * Checks whether the other party supports a given verification method.
237
- * This is useful when setting up the QR code UI, as it is somewhat asymmetrical:
238
- * if the other party supports SCAN_QR, we should show a QR code in the UI, and vice versa.
239
- * For methods that need to be supported by both ends, use the `methods` property.
240
- *
241
- * @param method - the method to check
242
- * @returns true if the other party said they supported the method
243
- */
244
- otherPartySupportsMethod(method) {
245
- var theirMethods = this.inner.theirSupportedMethods;
246
- if (theirMethods === undefined) {
247
- // no message from the other side yet
248
- return false;
249
- }
250
- var requiredMethod = verificationMethodsByIdentifier[method];
251
- return theirMethods.some(m => m === requiredMethod);
252
- }
253
-
254
- /**
255
- * Accepts the request, sending a .ready event to the other party
256
- *
257
- * @returns Promise which resolves when the event has been sent.
258
- */
259
- accept() {
260
- var _this2 = this;
261
- return _asyncToGenerator(function* () {
262
- if (_this2.inner.phase() !== RustSdkCryptoJs.VerificationRequestPhase.Requested || _this2._accepting) {
263
- throw new Error("Cannot accept a verification request in phase ".concat(_this2.phase));
264
- }
265
- _this2._accepting = true;
266
- try {
267
- var req = _this2.inner.acceptWithMethods(_this2.supportedVerificationMethods.map(verificationMethodIdentifierToMethod));
268
- if (req) {
269
- yield _this2.outgoingRequestProcessor.makeOutgoingRequest(req);
270
- }
271
- } finally {
272
- _this2._accepting = false;
273
- }
274
-
275
- // phase may have changed, so emit a 'change' event
276
- _this2.emit(VerificationRequestEvent.Change);
277
- })();
278
- }
279
-
280
- /**
281
- * Cancels the request, sending a cancellation to the other party
282
- *
283
- * @param params - Details for the cancellation, including `reason` (defaults to "User declined"), and `code`
284
- * (defaults to `m.user`).
285
- *
286
- * @returns Promise which resolves when the event has been sent.
287
- */
288
- cancel(params) {
289
- var _this3 = this;
290
- return _asyncToGenerator(function* () {
291
- if (_this3._cancelling) {
292
- // already cancelling; do nothing
293
- return;
294
- }
295
- _this3._cancelling = true;
296
- try {
297
- var req = _this3.inner.cancel();
298
- if (req) {
299
- yield _this3.outgoingRequestProcessor.makeOutgoingRequest(req);
300
- }
301
- } finally {
302
- _this3._cancelling = false;
303
- }
304
- })();
305
- }
306
-
307
- /**
308
- * Create a {@link Verifier} to do this verification via a particular method.
309
- *
310
- * If a verifier has already been created for this request, returns that verifier.
311
- *
312
- * This does *not* send the `m.key.verification.start` event - to do so, call {@link Verifier#verifier} on the
313
- * returned verifier.
314
- *
315
- * If no previous events have been sent, pass in `targetDevice` to set who to direct this request to.
316
- *
317
- * @param method - the name of the verification method to use.
318
- * @param targetDevice - details of where to send the request to.
319
- *
320
- * @returns The verifier which will do the actual verification.
321
- */
322
- beginKeyVerification(method, targetDevice) {
323
- throw new Error("not implemented");
324
- }
325
-
326
- /**
327
- * Send an `m.key.verification.start` event to start verification via a particular method.
328
- *
329
- * Implementation of {@link Crypto.VerificationRequest#startVerification}.
330
- *
331
- * @param method - the name of the verification method to use.
332
- */
333
- startVerification(method) {
334
- var _this4 = this;
335
- return _asyncToGenerator(function* () {
336
- if (method !== VerificationMethod.Sas) {
337
- throw new Error("Unsupported verification method ".concat(method));
338
- }
339
-
340
- // make sure that we have a list of the other user's devices (workaround https://github.com/matrix-org/matrix-rust-sdk/issues/2896)
341
- if (!(yield _this4.getOtherDevice())) {
342
- throw new Error("startVerification(): other device is unknown");
343
- }
344
- var res = yield _this4.inner.startSas();
345
- if (res) {
346
- var [, req] = res;
347
- yield _this4.outgoingRequestProcessor.makeOutgoingRequest(req);
348
- }
349
-
350
- // this should have triggered the onChange callback, and we should now have a verifier
351
- if (!_this4._verifier) {
352
- throw new Error("Still no verifier after startSas() call");
353
- }
354
- return _this4._verifier;
355
- })();
356
- }
357
-
358
- /**
359
- * Start a QR code verification by providing a scanned QR code for this verification flow.
360
- *
361
- * Implementation of {@link Crypto.VerificationRequest#scanQRCode}.
362
- *
363
- * @param qrCodeData - the decoded QR code.
364
- * @returns A verifier; call `.verify()` on it to wait for the other side to complete the verification flow.
365
- */
366
- scanQRCode(uint8Array) {
367
- var _this5 = this;
368
- return _asyncToGenerator(function* () {
369
- var scan = RustSdkCryptoJs.QrCodeScan.fromBytes(new Uint8ClampedArray(uint8Array));
370
- var verifier = yield _this5.inner.scanQrCode(scan);
371
-
372
- // this should have triggered the onChange callback, and we should now have a verifier
373
- if (!_this5._verifier) {
374
- throw new Error("Still no verifier after scanQrCode() call");
375
- }
376
-
377
- // we can immediately trigger the reciprocate request
378
- var req = verifier.reciprocate();
379
- if (req) {
380
- yield _this5.outgoingRequestProcessor.makeOutgoingRequest(req);
381
- }
382
- return _this5._verifier;
383
- })();
384
- }
385
-
386
- /**
387
- * The verifier which is doing the actual verification, once the method has been established.
388
- * Only defined when the `phase` is Started.
389
- */
390
- get verifier() {
391
- // It's possible for us to have a Verifier before a method has been chosen (in particular,
392
- // if we are showing a QR code which the other device has not yet scanned. At that point, we could
393
- // still switch to SAS).
394
- //
395
- // In that case, we should not return it to the application yet, since the application will not expect the
396
- // Verifier to be replaced during the lifetime of the VerificationRequest.
397
- return this.phase === VerificationPhase.Started ? this._verifier : undefined;
398
- }
399
-
400
- /**
401
- * Stub implementation of {@link Crypto.VerificationRequest#getQRCodeBytes}.
402
- */
403
- getQRCodeBytes() {
404
- throw new Error("getQRCodeBytes() unsupported in Rust Crypto; use generateQRCode() instead.");
405
- }
406
-
407
- /**
408
- * Generate the data for a QR code allowing the other device to verify this one, if it supports it.
409
- *
410
- * Implementation of {@link Crypto.VerificationRequest#generateQRCode}.
411
- */
412
- generateQRCode() {
413
- var _this6 = this;
414
- return _asyncToGenerator(function* () {
415
- // make sure that we have a list of the other user's devices (workaround https://github.com/matrix-org/matrix-rust-sdk/issues/2896)
416
- if (!(yield _this6.getOtherDevice())) {
417
- throw new Error("generateQRCode(): other device is unknown");
418
- }
419
- var innerVerifier = yield _this6.inner.generateQrCode();
420
- // If we are unable to generate a QRCode, we return undefined
421
- if (!innerVerifier) return;
422
- return Buffer.from(innerVerifier.toBytes());
423
- })();
424
- }
425
-
426
- /**
427
- * If this request has been cancelled, the cancellation code (e.g `m.user`) which is responsible for cancelling
428
- * this verification.
429
- */
430
- get cancellationCode() {
431
- var _this$inner$cancelInf, _this$inner$cancelInf2;
432
- return (_this$inner$cancelInf = (_this$inner$cancelInf2 = this.inner.cancelInfo) === null || _this$inner$cancelInf2 === void 0 ? void 0 : _this$inner$cancelInf2.cancelCode()) !== null && _this$inner$cancelInf !== void 0 ? _this$inner$cancelInf : null;
433
- }
434
-
435
- /**
436
- * The id of the user that cancelled the request.
437
- *
438
- * Only defined when phase is Cancelled
439
- */
440
- get cancellingUserId() {
441
- var cancelInfo = this.inner.cancelInfo;
442
- if (!cancelInfo) {
443
- return undefined;
444
- } else if (cancelInfo.cancelledbyUs()) {
445
- return this.olmMachine.userId.toString();
446
- } else {
447
- return this.inner.otherUserId.toString();
448
- }
449
- }
450
- }
451
-
452
- /** Common base class for `Verifier` implementations which wrap rust classes.
453
- *
454
- * The generic parameter `InnerType` is the type of the rust Verification class which we wrap.
455
- *
456
- * @internal
457
- */
458
- class BaseRustVerifer extends TypedEventEmitter {
459
- constructor(inner, outgoingRequestProcessor) {
460
- super();
461
- this.inner = inner;
462
- this.outgoingRequestProcessor = outgoingRequestProcessor;
463
- /** A deferred which completes when the verification completes (or rejects when it is cancelled/fails) */
464
- _defineProperty(this, "completionDeferred", void 0);
465
- this.completionDeferred = defer();
466
-
467
- // As with RustVerificationRequest, we need to avoid a reference cycle.
468
- // See the comments in RustVerificationRequest.
469
- var weakThis = new WeakRef(this);
470
- inner.registerChangesCallback(/*#__PURE__*/_asyncToGenerator(function* () {
471
- var _weakThis$deref2;
472
- return (_weakThis$deref2 = weakThis.deref()) === null || _weakThis$deref2 === void 0 ? void 0 : _weakThis$deref2.onChange();
473
- }));
474
-
475
- // stop the runtime complaining if nobody catches a failure
476
- this.completionDeferred.promise.catch(() => null);
477
- }
478
-
479
- /**
480
- * Hook which is called when the underlying rust class notifies us that there has been a change.
481
- *
482
- * Can be overridden by subclasses to see if we can notify the application about an update. The overriding method
483
- * must call `super.onChange()`.
484
- */
485
- onChange() {
486
- if (this.inner.isDone()) {
487
- this.completionDeferred.resolve(undefined);
488
- } else if (this.inner.isCancelled()) {
489
- var cancelInfo = this.inner.cancelInfo();
490
- this.completionDeferred.reject(new Error("Verification cancelled by ".concat(cancelInfo.cancelledbyUs() ? "us" : "them", " with code ").concat(cancelInfo.cancelCode(), ": ").concat(cancelInfo.reason())));
491
- }
492
- this.emit(VerificationRequestEvent.Change);
493
- }
494
-
495
- /**
496
- * Returns true if the verification has been cancelled, either by us or the other side.
497
- */
498
- get hasBeenCancelled() {
499
- return this.inner.isCancelled();
500
- }
501
-
502
- /**
503
- * The ID of the other user in the verification process.
504
- */
505
- get userId() {
506
- return this.inner.otherUserId.toString();
507
- }
508
-
509
- /**
510
- * Cancel a verification.
511
- *
512
- * We will send an `m.key.verification.cancel` if the verification is still in flight. The verification promise
513
- * will reject, and a {@link Crypto.VerifierEvent#Cancel} will be emitted.
514
- *
515
- * @param e - the reason for the cancellation.
516
- */
517
- cancel(e) {
518
- // TODO: something with `e`
519
- var req = this.inner.cancel();
520
- if (req) {
521
- this.outgoingRequestProcessor.makeOutgoingRequest(req);
522
- }
523
- }
524
-
525
- /**
526
- * Get the details for an SAS verification, if one is in progress
527
- *
528
- * Returns `null`, unless this verifier is for a SAS-based verification and we are waiting for the user to confirm
529
- * the SAS matches.
530
- */
531
- getShowSasCallbacks() {
532
- return null;
533
- }
534
-
535
- /**
536
- * Get the details for reciprocating QR code verification, if one is in progress
537
- *
538
- * Returns `null`, unless this verifier is for reciprocating a QR-code-based verification (ie, the other user has
539
- * already scanned our QR code), and we are waiting for the user to confirm.
540
- */
541
- getReciprocateQrCodeCallbacks() {
542
- return null;
543
- }
544
- }
545
-
546
- /** A Verifier instance which is used to show and/or scan a QR code. */
547
- export class RustQrCodeVerifier extends BaseRustVerifer {
548
- constructor(inner, outgoingRequestProcessor) {
549
- super(inner, outgoingRequestProcessor);
550
- _defineProperty(this, "callbacks", null);
551
- }
552
- onChange() {
553
- // if the other side has scanned our QR code and sent us a "reciprocate" message, it is now time for the
554
- // application to prompt the user to confirm their side.
555
- if (this.callbacks === null && this.inner.hasBeenScanned()) {
556
- this.callbacks = {
557
- confirm: () => {
558
- this.confirmScanning();
559
- },
560
- cancel: () => this.cancel()
561
- };
562
- }
563
- super.onChange();
564
- }
565
-
566
- /**
567
- * Start the key verification, if it has not already been started.
568
- *
569
- * @returns Promise which resolves when the verification has completed, or rejects if the verification is cancelled
570
- * or times out.
571
- */
572
- verify() {
573
- var _this7 = this;
574
- return _asyncToGenerator(function* () {
575
- // Some applications (hello, matrix-react-sdk) may not check if there is a `ShowQrCodeCallbacks` and instead
576
- // register a `ShowReciprocateQr` listener which they expect to be called once `.verify` is called.
577
- if (_this7.callbacks !== null) {
578
- _this7.emit(VerifierEvent.ShowReciprocateQr, _this7.callbacks);
579
- }
580
- // Nothing to do here but wait.
581
- yield _this7.completionDeferred.promise;
582
- })();
583
- }
584
-
585
- /**
586
- * Calculate an appropriate VerificationPhase for a VerificationRequest where this is the verifier.
587
- *
588
- * This is abnormally complicated because a rust-side QR Code verifier can span several verification phases.
589
- */
590
- get verificationPhase() {
591
- switch (this.inner.state()) {
592
- case QrState.Created:
593
- // we have created a QR for display; neither side has yet sent an `m.key.verification.start`.
594
- return VerificationPhase.Ready;
595
- case QrState.Scanned:
596
- // other side has scanned our QR and sent an `m.key.verification.start` with `m.reciprocate.v1`
597
- return VerificationPhase.Started;
598
- case QrState.Confirmed:
599
- // we have confirmed the other side's scan and sent an `m.key.verification.done`.
600
- //
601
- // However, the verification is not yet "Done", because we have to wait until we have received the
602
- // `m.key.verification.done` from the other side (in particular, we don't mark the device/identity as
603
- // verified until that happens). If we return "Done" too soon, we risk the user cancelling the flow.
604
- return VerificationPhase.Started;
605
- case QrState.Reciprocated:
606
- // although the rust SDK doesn't immediately send the `m.key.verification.start` on transition into this
607
- // state, `RustVerificationRequest.scanQrCode` immediately calls `reciprocate()` and does so, so in practice
608
- // we can treat the two the same.
609
- return VerificationPhase.Started;
610
- case QrState.Done:
611
- return VerificationPhase.Done;
612
- case QrState.Cancelled:
613
- return VerificationPhase.Cancelled;
614
- default:
615
- throw new Error("Unknown qr code state ".concat(this.inner.state()));
616
- }
617
- }
618
-
619
- /**
620
- * Get the details for reciprocating QR code verification, if one is in progress
621
- *
622
- * Returns `null`, unless this verifier is for reciprocating a QR-code-based verification (ie, the other user has
623
- * already scanned our QR code), and we are waiting for the user to confirm.
624
- */
625
- getReciprocateQrCodeCallbacks() {
626
- return this.callbacks;
627
- }
628
- confirmScanning() {
629
- var _this8 = this;
630
- return _asyncToGenerator(function* () {
631
- var req = _this8.inner.confirmScanning();
632
- if (req) {
633
- yield _this8.outgoingRequestProcessor.makeOutgoingRequest(req);
634
- }
635
- })();
636
- }
637
- }
638
-
639
- /** A Verifier instance which is used if we are exchanging emojis */
640
- export class RustSASVerifier extends BaseRustVerifer {
641
- constructor(inner, _verificationRequest, outgoingRequestProcessor) {
642
- super(inner, outgoingRequestProcessor);
643
- _defineProperty(this, "callbacks", null);
644
- }
645
-
646
- /**
647
- * Start the key verification, if it has not already been started.
648
- *
649
- * This means sending a `m.key.verification.start` if we are the first responder, or a `m.key.verification.accept`
650
- * if the other side has already sent a start event.
651
- *
652
- * @returns Promise which resolves when the verification has completed, or rejects if the verification is cancelled
653
- * or times out.
654
- */
655
- verify() {
656
- var _this9 = this;
657
- return _asyncToGenerator(function* () {
658
- yield _this9.sendAccept();
659
- yield _this9.completionDeferred.promise;
660
- })();
661
- }
662
-
663
- /**
664
- * Send the accept or start event, if it hasn't already been sent
665
- */
666
- sendAccept() {
667
- var _this10 = this;
668
- return _asyncToGenerator(function* () {
669
- var req = _this10.inner.accept();
670
- if (req) {
671
- yield _this10.outgoingRequestProcessor.makeOutgoingRequest(req);
672
- }
673
- })();
674
- }
675
-
676
- /** if we can now show the callbacks, do so */
677
- onChange() {
678
- var _this11 = this;
679
- super.onChange();
680
- if (this.callbacks === null) {
681
- var emoji = this.inner.emoji();
682
- var decimal = this.inner.decimals();
683
- if (emoji === undefined && decimal === undefined) {
684
- return;
685
- }
686
- var sas = {};
687
- if (emoji) {
688
- sas.emoji = emoji.map(e => [e.symbol, e.description]);
689
- }
690
- if (decimal) {
691
- sas.decimal = [decimal[0], decimal[1], decimal[2]];
692
- }
693
- this.callbacks = {
694
- sas,
695
- confirm: function () {
696
- var _confirm = _asyncToGenerator(function* () {
697
- var requests = yield _this11.inner.confirm();
698
- for (var m of requests) {
699
- yield _this11.outgoingRequestProcessor.makeOutgoingRequest(m);
700
- }
701
- });
702
- function confirm() {
703
- return _confirm.apply(this, arguments);
704
- }
705
- return confirm;
706
- }(),
707
- mismatch: () => {
708
- var request = this.inner.cancelWithCode("m.mismatched_sas");
709
- if (request) {
710
- this.outgoingRequestProcessor.makeOutgoingRequest(request);
711
- }
712
- },
713
- cancel: () => {
714
- var request = this.inner.cancelWithCode("m.user");
715
- if (request) {
716
- this.outgoingRequestProcessor.makeOutgoingRequest(request);
717
- }
718
- }
719
- };
720
- this.emit(VerifierEvent.ShowSas, this.callbacks);
721
- }
722
- }
723
-
724
- /**
725
- * Calculate an appropriate VerificationPhase for a VerificationRequest where this is the verifier.
726
- */
727
- get verificationPhase() {
728
- return VerificationPhase.Started;
729
- }
730
-
731
- /**
732
- * Get the details for an SAS verification, if one is in progress
733
- *
734
- * Returns `null`, unless this verifier is for a SAS-based verification and we are waiting for the user to confirm
735
- * the SAS matches.
736
- */
737
- getShowSasCallbacks() {
738
- return this.callbacks;
739
- }
740
-
741
- /**
742
- * Replace the inner Rust verifier with a different one.
743
- *
744
- * @param inner - the new Rust verifier
745
- * @internal
746
- */
747
- replaceInner(inner) {
748
- if (this.inner != inner) {
749
- this.inner = inner;
750
-
751
- // As with RustVerificationRequest, we need to avoid a reference cycle.
752
- // See the comments in RustVerificationRequest.
753
- var weakThis = new WeakRef(this);
754
- inner.registerChangesCallback(/*#__PURE__*/_asyncToGenerator(function* () {
755
- var _weakThis$deref3;
756
- return (_weakThis$deref3 = weakThis.deref()) === null || _weakThis$deref3 === void 0 ? void 0 : _weakThis$deref3.onChange();
757
- }));
758
-
759
- // replaceInner will only get called if we started the verification at the same time as the other side, and we lost
760
- // the tie breaker. So we need to re-accept their verification.
761
- this.sendAccept();
762
- this.onChange();
763
- }
764
- }
765
- }
766
-
767
- /** For each specced verification method, the rust-side `VerificationMethod` corresponding to it */
768
- var verificationMethodsByIdentifier = {
769
- [VerificationMethod.Sas]: RustSdkCryptoJs.VerificationMethod.SasV1,
770
- [VerificationMethod.ScanQrCode]: RustSdkCryptoJs.VerificationMethod.QrCodeScanV1,
771
- [VerificationMethod.ShowQrCode]: RustSdkCryptoJs.VerificationMethod.QrCodeShowV1,
772
- [VerificationMethod.Reciprocate]: RustSdkCryptoJs.VerificationMethod.ReciprocateV1
773
- };
774
-
775
- /**
776
- * Convert a specced verification method identifier into a rust-side `VerificationMethod`.
777
- *
778
- * @param method - specced method identifier, for example `m.sas.v1`.
779
- * @returns Rust-side `VerificationMethod` corresponding to `method`.
780
- * @throws An error if the method is unknown.
781
- *
782
- * @internal
783
- */
784
- export function verificationMethodIdentifierToMethod(method) {
785
- var meth = verificationMethodsByIdentifier[method];
786
- if (meth === undefined) {
787
- throw new Error("Unknown verification method ".concat(method));
788
- }
789
- return meth;
790
- }
791
-
792
- /**
793
- * Return true if the event's type matches that of an in-room verification event
794
- *
795
- * @param event - MatrixEvent
796
- * @returns
797
- *
798
- * @internal
799
- */
800
- export function isVerificationEvent(event) {
801
- switch (event.getType()) {
802
- case EventType.KeyVerificationCancel:
803
- case EventType.KeyVerificationDone:
804
- case EventType.KeyVerificationMac:
805
- case EventType.KeyVerificationStart:
806
- case EventType.KeyVerificationKey:
807
- case EventType.KeyVerificationReady:
808
- case EventType.KeyVerificationAccept:
809
- return true;
810
- case EventType.RoomMessage:
811
- return event.getContent().msgtype === MsgType.KeyVerificationRequest;
812
- default:
813
- return false;
814
- }
815
- }
816
- //# sourceMappingURL=verification.js.map