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