@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,881 +0,0 @@
1
- /*
2
- Copyright 2023 - 2024 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 { OlmMachine, SignatureVerification } from "@matrix-org/matrix-sdk-crypto-wasm";
18
- import * as RustSdkCryptoJs from "@matrix-org/matrix-sdk-crypto-wasm";
19
-
20
- import {
21
- BackupTrustInfo,
22
- Curve25519AuthData,
23
- KeyBackupCheck,
24
- KeyBackupInfo,
25
- KeyBackupSession,
26
- Curve25519SessionData,
27
- KeyBackupRestoreOpts,
28
- KeyBackupRestoreResult,
29
- KeyBackupRoomSessions,
30
- } from "../crypto-api/keybackup.ts";
31
- import { logger } from "../logger.ts";
32
- import { ClientPrefix, IHttpOpts, MatrixError, MatrixHttpApi, Method } from "../http-api/index.ts";
33
- import { IMegolmSessionData } from "../crypto/index.ts";
34
- import { TypedEventEmitter } from "../models/typed-event-emitter.ts";
35
- import { encodeUri, logDuration } from "../utils.ts";
36
- import { OutgoingRequestProcessor } from "./OutgoingRequestProcessor.ts";
37
- import { sleep } from "../utils.ts";
38
- import { BackupDecryptor } from "../common-crypto/CryptoBackend.ts";
39
- import { ImportRoomKeyProgressData, ImportRoomKeysOpts, CryptoEvent } from "../crypto-api/index.ts";
40
- import { AESEncryptedSecretStoragePayload } from "../@types/AESEncryptedSecretStoragePayload.ts";
41
-
42
- /** Authentification of the backup info, depends on algorithm */
43
- type AuthData = KeyBackupInfo["auth_data"];
44
-
45
- /**
46
- * Holds information of a created keybackup.
47
- * Useful to get the generated private key material and save it securely somewhere.
48
- */
49
- interface KeyBackupCreationInfo {
50
- version: string;
51
- algorithm: string;
52
- authData: AuthData;
53
- decryptionKey: RustSdkCryptoJs.BackupDecryptionKey;
54
- }
55
-
56
- /**
57
- * @internal
58
- */
59
- export class RustBackupManager extends TypedEventEmitter<RustBackupCryptoEvents, RustBackupCryptoEventMap> {
60
- /** Have we checked if there is a backup on the server which we can use */
61
- private checkedForBackup = false;
62
-
63
- /**
64
- * The latest backup version on the server, when we last checked.
65
- *
66
- * If there was no backup on the server, `null`. If our attempt to check resulted in an error, `undefined`.
67
- *
68
- * Note that the backup was not necessarily verified.
69
- */
70
- private serverBackupInfo: KeyBackupInfo | null | undefined = undefined;
71
-
72
- private activeBackupVersion: string | null = null;
73
- private stopped = false;
74
-
75
- /** whether {@link backupKeysLoop} is currently running */
76
- private backupKeysLoopRunning = false;
77
-
78
- public constructor(
79
- private readonly olmMachine: OlmMachine,
80
- private readonly http: MatrixHttpApi<IHttpOpts & { onlyData: true }>,
81
- private readonly outgoingRequestProcessor: OutgoingRequestProcessor,
82
- ) {
83
- super();
84
- }
85
-
86
- /**
87
- * Tells the RustBackupManager to stop.
88
- * The RustBackupManager is scheduling background uploads of keys to the backup, this
89
- * call allows to cancel the process when the client is stoppped.
90
- */
91
- public stop(): void {
92
- this.stopped = true;
93
- }
94
-
95
- /**
96
- * Get the backup version we are currently backing up to, if any
97
- */
98
- public async getActiveBackupVersion(): Promise<string | null> {
99
- if (!(await this.olmMachine.isBackupEnabled())) return null;
100
- return this.activeBackupVersion;
101
- }
102
-
103
- /**
104
- * Return the details of the latest backup on the server, when we last checked.
105
- *
106
- * This normally returns a cached value, but if we haven't yet made a request to the server, it will fire one off.
107
- * It will always return the details of the active backup if key backup is enabled.
108
- *
109
- * If there was no backup on the server, `null`. If our attempt to check resulted in an error, `undefined`.
110
- */
111
- public async getServerBackupInfo(): Promise<KeyBackupInfo | null | undefined> {
112
- // Do a validity check if we haven't already done one. The check is likely to fail if we don't yet have the
113
- // backup keys -- but as a side-effect, it will populate `serverBackupInfo`.
114
- await this.checkKeyBackupAndEnable(false);
115
- return this.serverBackupInfo;
116
- }
117
-
118
- /**
119
- * Determine if a key backup can be trusted.
120
- *
121
- * @param info - key backup info dict from {@link MatrixClient#getKeyBackupVersion}.
122
- */
123
- public async isKeyBackupTrusted(info: KeyBackupInfo): Promise<BackupTrustInfo> {
124
- const signatureVerification: SignatureVerification = await this.olmMachine.verifyBackup(info);
125
-
126
- const backupKeys: RustSdkCryptoJs.BackupKeys = await this.olmMachine.getBackupKeys();
127
- const decryptionKey = backupKeys?.decryptionKey;
128
- const backupMatchesSavedPrivateKey =
129
- !!decryptionKey && backupInfoMatchesBackupDecryptionKey(info, decryptionKey);
130
- return {
131
- matchesDecryptionKey: backupMatchesSavedPrivateKey,
132
- trusted: signatureVerification.trusted(),
133
- };
134
- }
135
-
136
- /**
137
- * Re-check the key backup and enable/disable it as appropriate.
138
- *
139
- * @param force - whether we should force a re-check even if one has already happened.
140
- */
141
- public checkKeyBackupAndEnable(force: boolean): Promise<KeyBackupCheck | null> {
142
- if (!force && this.checkedForBackup) {
143
- return Promise.resolve(null);
144
- }
145
-
146
- // make sure there is only one check going on at a time
147
- if (!this.keyBackupCheckInProgress) {
148
- this.keyBackupCheckInProgress = this.doCheckKeyBackup().finally(() => {
149
- this.keyBackupCheckInProgress = null;
150
- });
151
- }
152
- return this.keyBackupCheckInProgress;
153
- }
154
-
155
- /**
156
- * Handles a backup secret received event and store it if it matches the current backup version.
157
- *
158
- * @param secret - The secret as received from a `m.secret.send` event for secret `m.megolm_backup.v1`.
159
- * @returns true if the secret is valid and has been stored, false otherwise.
160
- */
161
- public async handleBackupSecretReceived(secret: string): Promise<boolean> {
162
- // Currently we only receive the decryption key without any key backup version. It is important to
163
- // check that the secret is valid for the current version before storing it.
164
- // We force a check to ensure to have the latest version. We also want to check that the backup is trusted
165
- // as we don't want to store the secret if the backup is not trusted, and eventually import megolm keys later from an untrusted backup.
166
- const backupCheck = await this.checkKeyBackupAndEnable(true);
167
-
168
- if (!backupCheck?.backupInfo?.version || !backupCheck.trustInfo.trusted) {
169
- // There is no server-side key backup, or the backup is not signed by a trusted cross-signing key or trusted own device.
170
- // This decryption key is useless to us.
171
- logger.warn(
172
- "handleBackupSecretReceived: Received a backup decryption key, but there is no trusted server-side key backup",
173
- );
174
- return false;
175
- }
176
-
177
- try {
178
- const backupDecryptionKey = RustSdkCryptoJs.BackupDecryptionKey.fromBase64(secret);
179
- const privateKeyMatches = backupInfoMatchesBackupDecryptionKey(backupCheck.backupInfo, backupDecryptionKey);
180
- if (!privateKeyMatches) {
181
- logger.warn(
182
- `handleBackupSecretReceived: Private decryption key does not match the public key of the current remote backup.`,
183
- );
184
- // just ignore the secret
185
- return false;
186
- }
187
- logger.info(
188
- `handleBackupSecretReceived: A valid backup decryption key has been received and stored in cache.`,
189
- );
190
- await this.saveBackupDecryptionKey(backupDecryptionKey, backupCheck.backupInfo.version);
191
- return true;
192
- } catch (e) {
193
- logger.warn("handleBackupSecretReceived: Invalid backup decryption key", e);
194
- }
195
-
196
- return false;
197
- }
198
-
199
- public async saveBackupDecryptionKey(
200
- backupDecryptionKey: RustSdkCryptoJs.BackupDecryptionKey,
201
- version: string,
202
- ): Promise<void> {
203
- await this.olmMachine.saveBackupDecryptionKey(backupDecryptionKey, version);
204
- // Emit an event that we have a new backup decryption key, so that the sdk can start
205
- // importing keys from backup if needed.
206
- this.emit(CryptoEvent.KeyBackupDecryptionKeyCached, version);
207
- }
208
-
209
- /**
210
- * Import a list of room keys previously exported by exportRoomKeys
211
- *
212
- * @param keys - a list of session export objects
213
- * @param opts - options object
214
- * @returns a promise which resolves once the keys have been imported
215
- */
216
- public async importRoomKeys(keys: IMegolmSessionData[], opts?: ImportRoomKeysOpts): Promise<void> {
217
- await this.importRoomKeysAsJson(JSON.stringify(keys), opts);
218
- }
219
-
220
- /**
221
- * Import a list of room keys previously exported by exportRoomKeysAsJson
222
- *
223
- * @param jsonKeys - a JSON string encoding a list of session export objects,
224
- * each of which is an IMegolmSessionData
225
- * @param opts - options object
226
- * @returns a promise which resolves once the keys have been imported
227
- */
228
- public async importRoomKeysAsJson(jsonKeys: string, opts?: ImportRoomKeysOpts): Promise<void> {
229
- await this.olmMachine.importExportedRoomKeys(jsonKeys, (progress: bigint, total: bigint): void => {
230
- const importOpt: ImportRoomKeyProgressData = {
231
- total: Number(total),
232
- successes: Number(progress),
233
- stage: "load_keys",
234
- failures: 0,
235
- };
236
- opts?.progressCallback?.(importOpt);
237
- });
238
- }
239
-
240
- /**
241
- * Implementation of {@link CryptoBackend#importBackedUpRoomKeys}.
242
- */
243
- public async importBackedUpRoomKeys(
244
- keys: IMegolmSessionData[],
245
- backupVersion: string,
246
- opts?: ImportRoomKeysOpts,
247
- ): Promise<void> {
248
- const keysByRoom: Map<RustSdkCryptoJs.RoomId, Map<string, IMegolmSessionData>> = new Map();
249
- for (const key of keys) {
250
- const roomId = new RustSdkCryptoJs.RoomId(key.room_id);
251
- if (!keysByRoom.has(roomId)) {
252
- keysByRoom.set(roomId, new Map());
253
- }
254
- keysByRoom.get(roomId)!.set(key.session_id, key);
255
- }
256
- await this.olmMachine.importBackedUpRoomKeys(
257
- keysByRoom,
258
- (progress: bigint, total: bigint, failures: bigint): void => {
259
- const importOpt: ImportRoomKeyProgressData = {
260
- total: Number(total),
261
- successes: Number(progress),
262
- stage: "load_keys",
263
- failures: Number(failures),
264
- };
265
- opts?.progressCallback?.(importOpt);
266
- },
267
- backupVersion,
268
- );
269
- }
270
-
271
- private keyBackupCheckInProgress: Promise<KeyBackupCheck | null> | null = null;
272
-
273
- /** Helper for `checkKeyBackup` */
274
- private async doCheckKeyBackup(): Promise<KeyBackupCheck | null> {
275
- logger.log("Checking key backup status...");
276
- let backupInfo: KeyBackupInfo | null | undefined;
277
- try {
278
- backupInfo = await this.requestKeyBackupVersion();
279
- } catch (e) {
280
- logger.warn("Error checking for active key backup", e);
281
- this.serverBackupInfo = undefined;
282
- return null;
283
- }
284
- this.checkedForBackup = true;
285
-
286
- if (backupInfo && !backupInfo.version) {
287
- logger.warn("active backup lacks a useful 'version'; ignoring it");
288
- backupInfo = undefined;
289
- }
290
- this.serverBackupInfo = backupInfo;
291
-
292
- const activeVersion = await this.getActiveBackupVersion();
293
-
294
- if (!backupInfo) {
295
- if (activeVersion !== null) {
296
- logger.log("No key backup present on server: disabling key backup");
297
- await this.disableKeyBackup();
298
- } else {
299
- logger.log("No key backup present on server: not enabling key backup");
300
- }
301
- return null;
302
- }
303
-
304
- const trustInfo = await this.isKeyBackupTrusted(backupInfo);
305
-
306
- if (!trustInfo.trusted) {
307
- if (activeVersion !== null) {
308
- logger.log("Key backup present on server but not trusted: disabling key backup");
309
- await this.disableKeyBackup();
310
- } else {
311
- logger.log("Key backup present on server but not trusted: not enabling key backup");
312
- }
313
- } else {
314
- if (activeVersion === null) {
315
- logger.log(`Found usable key backup v${backupInfo.version}: enabling key backups`);
316
- await this.enableKeyBackup(backupInfo);
317
- } else if (activeVersion !== backupInfo.version) {
318
- logger.log(`On backup version ${activeVersion} but found version ${backupInfo.version}: switching.`);
319
- // This will remove any pending backup request, remove the backup key and reset the backup state of each room key we have.
320
- await this.disableKeyBackup();
321
- // Enabling will now trigger re-upload of all the keys
322
- await this.enableKeyBackup(backupInfo);
323
- } else {
324
- logger.log(`Backup version ${backupInfo.version} still current`);
325
- }
326
- }
327
- return { backupInfo, trustInfo };
328
- }
329
-
330
- private async enableKeyBackup(backupInfo: KeyBackupInfo): Promise<void> {
331
- // we know for certain it must be a Curve25519 key, because we have verified it and only Curve25519
332
- // keys can be verified.
333
- //
334
- // we also checked it has a valid `version`.
335
- await this.olmMachine.enableBackupV1(
336
- (backupInfo.auth_data as Curve25519AuthData).public_key,
337
- backupInfo.version!,
338
- );
339
- this.activeBackupVersion = backupInfo.version!;
340
-
341
- this.emit(CryptoEvent.KeyBackupStatus, true);
342
-
343
- this.backupKeysLoop();
344
- }
345
-
346
- /**
347
- * Restart the backup key loop if there is an active trusted backup.
348
- * Doesn't try to check the backup server side. To be called when a new
349
- * megolm key is known locally.
350
- */
351
- public async maybeUploadKey(): Promise<void> {
352
- if (this.activeBackupVersion != null) {
353
- this.backupKeysLoop();
354
- }
355
- }
356
-
357
- private async disableKeyBackup(): Promise<void> {
358
- await this.olmMachine.disableBackup();
359
- this.activeBackupVersion = null;
360
- this.emit(CryptoEvent.KeyBackupStatus, false);
361
- }
362
-
363
- private async backupKeysLoop(maxDelay = 10000): Promise<void> {
364
- if (this.backupKeysLoopRunning) {
365
- logger.log(`Backup loop already running`);
366
- return;
367
- }
368
- this.backupKeysLoopRunning = true;
369
-
370
- logger.log(`Backup: Starting keys upload loop for backup version:${this.activeBackupVersion}.`);
371
-
372
- // wait between 0 and `maxDelay` seconds, to avoid backup
373
- // requests from different clients hitting the server all at
374
- // the same time when a new key is sent
375
- const delay = Math.random() * maxDelay;
376
- await sleep(delay);
377
-
378
- try {
379
- // number of consecutive network failures for exponential backoff
380
- let numFailures = 0;
381
- // The number of keys left to back up. (Populated lazily: see more comments below.)
382
- let remainingToUploadCount: number | null = null;
383
- // To avoid computing the key when only a few keys were added (after a sync for example),
384
- // we compute the count only when at least two iterations are needed.
385
- let isFirstIteration = true;
386
-
387
- while (!this.stopped) {
388
- // Get a batch of room keys to upload
389
- let request: RustSdkCryptoJs.KeysBackupRequest | null = null;
390
- try {
391
- request = await logDuration(
392
- logger,
393
- "BackupRoomKeys: Get keys to backup from rust crypto-sdk",
394
- async () => {
395
- return await this.olmMachine.backupRoomKeys();
396
- },
397
- );
398
- } catch (err) {
399
- logger.error("Backup: Failed to get keys to backup from rust crypto-sdk", err);
400
- }
401
-
402
- if (!request || this.stopped || !this.activeBackupVersion) {
403
- logger.log(`Backup: Ending loop for version ${this.activeBackupVersion}.`);
404
- if (!request) {
405
- // nothing more to upload
406
- this.emit(CryptoEvent.KeyBackupSessionsRemaining, 0);
407
- }
408
- return;
409
- }
410
-
411
- try {
412
- await this.outgoingRequestProcessor.makeOutgoingRequest(request);
413
- numFailures = 0;
414
- if (this.stopped) break;
415
-
416
- // Key count performance (`olmMachine.roomKeyCounts()`) can be pretty bad on some configurations.
417
- // In particular, we detected on some M1 macs that when the object store reaches a threshold, the count
418
- // performance stops growing in O(n) and suddenly becomes very slow (40s, 60s or more).
419
- // For reference, the performance drop occurs around 300-400k keys on the platforms where this issue is observed.
420
- // Even on other configurations, the count can take several seconds.
421
- // This will block other operations on the database, like sending messages.
422
- //
423
- // This is a workaround to avoid calling `olmMachine.roomKeyCounts()` too often, and only when necessary.
424
- // We don't call it on the first loop because there could be only a few keys to upload, and we don't want to wait for the count.
425
- if (!isFirstIteration && remainingToUploadCount === null) {
426
- try {
427
- const keyCount = await this.olmMachine.roomKeyCounts();
428
- remainingToUploadCount = keyCount.total - keyCount.backedUp;
429
- } catch (err) {
430
- logger.error("Backup: Failed to get key counts from rust crypto-sdk", err);
431
- }
432
- }
433
-
434
- if (remainingToUploadCount !== null) {
435
- this.emit(CryptoEvent.KeyBackupSessionsRemaining, remainingToUploadCount);
436
- const keysCountInBatch = this.keysCountInBatch(request);
437
- // `OlmMachine.roomKeyCounts` is called only once for the current backupKeysLoop. But new
438
- // keys could be added during the current loop (after a sync for example).
439
- // So the count can get out of sync with the real number of remaining keys to upload.
440
- // Depending on the number of new keys imported and the time to complete the loop,
441
- // this could result in multiple events being emitted with a remaining key count of 0.
442
- remainingToUploadCount = Math.max(remainingToUploadCount - keysCountInBatch, 0);
443
- }
444
- } catch (err) {
445
- numFailures++;
446
- logger.error("Backup: Error processing backup request for rust crypto-sdk", err);
447
- if (err instanceof MatrixError) {
448
- const errCode = err.data.errcode;
449
- if (errCode == "M_NOT_FOUND" || errCode == "M_WRONG_ROOM_KEYS_VERSION") {
450
- logger.log(`Backup: Failed to upload keys to current vesion: ${errCode}.`);
451
- try {
452
- await this.disableKeyBackup();
453
- } catch (error) {
454
- logger.error("Backup: An error occurred while disabling key backup:", error);
455
- }
456
- this.emit(CryptoEvent.KeyBackupFailed, err.data.errcode!);
457
- // There was an active backup and we are out of sync with the server
458
- // force a check server side
459
- this.backupKeysLoopRunning = false;
460
- this.checkKeyBackupAndEnable(true);
461
- return;
462
- } else if (err.isRateLimitError()) {
463
- // wait for that and then continue?
464
- try {
465
- const waitTime = err.getRetryAfterMs();
466
- if (waitTime && waitTime > 0) {
467
- await sleep(waitTime);
468
- continue;
469
- }
470
- } catch (error) {
471
- logger.warn(
472
- "Backup: An error occurred while retrieving a rate-limit retry delay",
473
- error,
474
- );
475
- } // else go to the normal backoff
476
- }
477
- }
478
-
479
- // Some other errors (mx, network, or CORS or invalid urls?) anyhow backoff
480
- // exponential backoff if we have failures
481
- await sleep(1000 * Math.pow(2, Math.min(numFailures - 1, 4)));
482
- }
483
- isFirstIteration = false;
484
- }
485
- } finally {
486
- this.backupKeysLoopRunning = false;
487
- }
488
- }
489
-
490
- /**
491
- * Utility method to count the number of keys in a backup request, in order to update the remaining keys count.
492
- * This should be the chunk size of the backup request for all requests but the last, but we don't have access to it
493
- * (it's static in the Rust SDK).
494
- * @param batch - The backup request to count the keys from.
495
- *
496
- * @returns The number of keys in the backup request.
497
- */
498
- private keysCountInBatch(batch: RustSdkCryptoJs.KeysBackupRequest): number {
499
- const parsedBody: KeyBackup = JSON.parse(batch.body);
500
- return countKeysInBackup(parsedBody);
501
- }
502
-
503
- /**
504
- * Get information about a key backup from the server
505
- * - If version is provided, get information about that backup version.
506
- * - If no version is provided, get information about the latest backup.
507
- *
508
- * @param version - The version of the backup to get information about.
509
- * @returns Information object from API or null if there is no active backup.
510
- */
511
- public async requestKeyBackupVersion(version?: string): Promise<KeyBackupInfo | null> {
512
- return await requestKeyBackupVersion(this.http, version);
513
- }
514
-
515
- /**
516
- * Creates a new key backup by generating a new random private key.
517
- *
518
- * If there is an existing backup server side it will be deleted and replaced
519
- * by the new one.
520
- *
521
- * @param signObject - Method that should sign the backup with existing device and
522
- * existing identity.
523
- * @returns a KeyBackupCreationInfo - All information related to the backup.
524
- */
525
- public async setupKeyBackup(signObject: (authData: AuthData) => Promise<void>): Promise<KeyBackupCreationInfo> {
526
- // Clean up any existing backup
527
- await this.deleteAllKeyBackupVersions();
528
-
529
- const randomKey = RustSdkCryptoJs.BackupDecryptionKey.createRandomKey();
530
- const pubKey = randomKey.megolmV1PublicKey;
531
-
532
- const authData = { public_key: pubKey.publicKeyBase64 };
533
-
534
- await signObject(authData);
535
-
536
- const res = await this.http.authedRequest<{ version: string }>(
537
- Method.Post,
538
- "/room_keys/version",
539
- undefined,
540
- {
541
- algorithm: pubKey.algorithm,
542
- auth_data: authData,
543
- },
544
- {
545
- prefix: ClientPrefix.V3,
546
- },
547
- );
548
-
549
- await this.saveBackupDecryptionKey(randomKey, res.version);
550
-
551
- return {
552
- version: res.version,
553
- algorithm: pubKey.algorithm,
554
- authData: authData,
555
- decryptionKey: randomKey,
556
- };
557
- }
558
-
559
- /**
560
- * Deletes all key backups.
561
- *
562
- * Will call the API to delete active backup until there is no more present.
563
- */
564
- public async deleteAllKeyBackupVersions(): Promise<void> {
565
- // there could be several backup versions. Delete all to be safe.
566
- let current = (await this.requestKeyBackupVersion())?.version ?? null;
567
- while (current != null) {
568
- await this.deleteKeyBackupVersion(current);
569
- current = (await this.requestKeyBackupVersion())?.version ?? null;
570
- }
571
-
572
- // XXX: Should this also update Secret Storage and delete any existing keys?
573
- }
574
-
575
- /**
576
- * Deletes the given key backup.
577
- *
578
- * @param version - The backup version to delete.
579
- */
580
- public async deleteKeyBackupVersion(version: string): Promise<void> {
581
- logger.debug(`deleteKeyBackupVersion v:${version}`);
582
- const path = encodeUri("/room_keys/version/$version", { $version: version });
583
- await this.http.authedRequest<void>(Method.Delete, path, undefined, undefined, {
584
- prefix: ClientPrefix.V3,
585
- });
586
- }
587
-
588
- /**
589
- * Creates a new backup decryptor for the given private key.
590
- * @param decryptionKey - The private key to use for decryption.
591
- */
592
- public createBackupDecryptor(decryptionKey: RustSdkCryptoJs.BackupDecryptionKey): BackupDecryptor {
593
- return new RustBackupDecryptor(decryptionKey);
594
- }
595
-
596
- /**
597
- * Restore a key backup.
598
- *
599
- * @param backupVersion - The version of the backup to restore.
600
- * @param backupDecryptor - The backup decryptor to use to decrypt the keys.
601
- * @param opts - Options for the restore.
602
- * @returns The total number of keys and the total imported.
603
- */
604
- public async restoreKeyBackup(
605
- backupVersion: string,
606
- backupDecryptor: BackupDecryptor,
607
- opts?: KeyBackupRestoreOpts,
608
- ): Promise<KeyBackupRestoreResult> {
609
- const keyBackup = await this.downloadKeyBackup(backupVersion);
610
- opts?.progressCallback?.({
611
- stage: "load_keys",
612
- });
613
-
614
- return this.importKeyBackup(keyBackup, backupVersion, backupDecryptor, opts);
615
- }
616
-
617
- /**
618
- * Call `/room_keys/keys` to download the key backup (room keys) for the given backup version.
619
- * https://spec.matrix.org/v1.12/client-server-api/#get_matrixclientv3room_keyskeys
620
- *
621
- * @param backupVersion
622
- * @returns The key backup response.
623
- */
624
- private downloadKeyBackup(backupVersion: string): Promise<KeyBackup> {
625
- return this.http.authedRequest<KeyBackup>(
626
- Method.Get,
627
- "/room_keys/keys",
628
- { version: backupVersion },
629
- undefined,
630
- {
631
- prefix: ClientPrefix.V3,
632
- },
633
- );
634
- }
635
-
636
- /**
637
- * Import the room keys from a `/room_keys/keys` call.
638
- * Calls `opts.progressCallback` with the progress of the import.
639
- *
640
- * @param keyBackup - The response from the server containing the keys to import.
641
- * @param backupVersion - The version of the backup info.
642
- * @param backupDecryptor - The backup decryptor to use to decrypt the keys.
643
- * @param opts - Options for the import.
644
- *
645
- * @returns The total number of keys and the total imported.
646
- *
647
- * @private
648
- */
649
- private async importKeyBackup(
650
- keyBackup: KeyBackup,
651
- backupVersion: string,
652
- backupDecryptor: BackupDecryptor,
653
- opts?: KeyBackupRestoreOpts,
654
- ): Promise<KeyBackupRestoreResult> {
655
- // We have a full backup here, it can get quite big, so we need to decrypt and import it in chunks.
656
-
657
- const CHUNK_SIZE = 200;
658
- // Get the total count as a first pass
659
- const totalKeyCount = countKeysInBackup(keyBackup);
660
- let totalImported = 0;
661
- let totalFailures = 0;
662
-
663
- /**
664
- * This method is called when we have enough chunks to decrypt.
665
- * It will decrypt the chunks and try to import the room keys.
666
- * @param roomChunks
667
- */
668
- const handleChunkCallback = async (roomChunks: Map<string, KeyBackupRoomSessions>): Promise<void> => {
669
- const currentChunk: IMegolmSessionData[] = [];
670
- for (const roomId of roomChunks.keys()) {
671
- // Decrypt the sessions for the given room
672
- const decryptedSessions = await backupDecryptor.decryptSessions(roomChunks.get(roomId)!);
673
- // Add the decrypted sessions to the current chunk
674
- decryptedSessions.forEach((session) => {
675
- // We set the room_id for each session
676
- session.room_id = roomId;
677
- currentChunk.push(session);
678
- });
679
- }
680
-
681
- // We have a chunk of decrypted keys: import them
682
- try {
683
- await this.importBackedUpRoomKeys(currentChunk, backupVersion);
684
- totalImported += currentChunk.length;
685
- } catch (e) {
686
- totalFailures += currentChunk.length;
687
- // We failed to import some keys, but we should still try to import the rest?
688
- // Log the error and continue
689
- logger.error("Error importing keys from backup", e);
690
- }
691
-
692
- opts?.progressCallback?.({
693
- total: totalKeyCount,
694
- successes: totalImported,
695
- stage: "load_keys",
696
- failures: totalFailures,
697
- });
698
- };
699
-
700
- let groupChunkCount = 0;
701
- let chunkGroupByRoom: Map<string, KeyBackupRoomSessions> = new Map();
702
-
703
- // Iterate over the rooms and sessions to group them in chunks
704
- // And we call the handleChunkCallback when we have enough chunks to decrypt
705
- for (const [roomId, roomData] of Object.entries(keyBackup.rooms)) {
706
- // If there are no sessions for the room, skip it
707
- if (!roomData.sessions) continue;
708
-
709
- // Initialize a new chunk group for the current room
710
- chunkGroupByRoom.set(roomId, {});
711
-
712
- for (const [sessionId, session] of Object.entries(roomData.sessions)) {
713
- // We set previously the chunk group for the current room, so we can safely get it
714
- const sessionsForRoom = chunkGroupByRoom.get(roomId)!;
715
- sessionsForRoom[sessionId] = session;
716
- groupChunkCount += 1;
717
- // If we have enough chunks to decrypt, call the block callback
718
- if (groupChunkCount >= CHUNK_SIZE) {
719
- // We have enough chunks to decrypt
720
- await handleChunkCallback(chunkGroupByRoom);
721
- // Reset the chunk group
722
- chunkGroupByRoom = new Map();
723
- // There might be remaining keys for that room, so add back an entry for the current room.
724
- chunkGroupByRoom.set(roomId, {});
725
- groupChunkCount = 0;
726
- }
727
- }
728
- }
729
-
730
- // Handle remaining chunk if needed
731
- if (groupChunkCount > 0) {
732
- await handleChunkCallback(chunkGroupByRoom);
733
- }
734
-
735
- return { total: totalKeyCount, imported: totalImported };
736
- }
737
- }
738
-
739
- /**
740
- * Checks if the provided backup info matches the given private key.
741
- *
742
- * @param info - The backup info to check.
743
- * @param backupDecryptionKey - The `BackupDecryptionKey` private key to check against.
744
- * @returns `true` if the private key can decrypt the backup, `false` otherwise.
745
- */
746
- function backupInfoMatchesBackupDecryptionKey(
747
- info: KeyBackupInfo,
748
- backupDecryptionKey: RustSdkCryptoJs.BackupDecryptionKey,
749
- ): boolean {
750
- if (info.algorithm !== "m.megolm_backup.v1.curve25519-aes-sha2") {
751
- logger.warn("backupMatchesPrivateKey: Unsupported backup algorithm", info.algorithm);
752
- return false;
753
- }
754
-
755
- return (info.auth_data as Curve25519AuthData)?.public_key === backupDecryptionKey.megolmV1PublicKey.publicKeyBase64;
756
- }
757
-
758
- /**
759
- * Implementation of {@link BackupDecryptor} for the rust crypto backend.
760
- */
761
- export class RustBackupDecryptor implements BackupDecryptor {
762
- private decryptionKey: RustSdkCryptoJs.BackupDecryptionKey;
763
- public sourceTrusted: boolean;
764
-
765
- public constructor(decryptionKey: RustSdkCryptoJs.BackupDecryptionKey) {
766
- this.decryptionKey = decryptionKey;
767
- this.sourceTrusted = false;
768
- }
769
-
770
- /**
771
- * Implements {@link BackupDecryptor#decryptSessions}
772
- */
773
- public async decryptSessions(
774
- ciphertexts: Record<string, KeyBackupSession<Curve25519SessionData | AESEncryptedSecretStoragePayload>>,
775
- ): Promise<IMegolmSessionData[]> {
776
- const keys: IMegolmSessionData[] = [];
777
- for (const [sessionId, sessionData] of Object.entries(ciphertexts)) {
778
- try {
779
- const decrypted = JSON.parse(
780
- this.decryptionKey.decryptV1(
781
- sessionData.session_data.ephemeral,
782
- sessionData.session_data.mac,
783
- sessionData.session_data.ciphertext,
784
- ),
785
- );
786
- decrypted.session_id = sessionId;
787
- keys.push(decrypted);
788
- } catch (e) {
789
- logger.log("Failed to decrypt megolm session from backup", e, sessionData);
790
- }
791
- }
792
- return keys;
793
- }
794
-
795
- /**
796
- * Implements {@link BackupDecryptor#free}
797
- */
798
- public free(): void {
799
- this.decryptionKey.free();
800
- }
801
- }
802
-
803
- /**
804
- * Fetch a key backup info from the server.
805
- *
806
- * If `version` is provided, calls `GET /room_keys/version/$version` and gets the backup info for that version.
807
- * See https://spec.matrix.org/v1.12/client-server-api/#get_matrixclientv3room_keysversionversion.
808
- *
809
- * If not, calls `GET /room_keys/version` and gets the latest backup info.
810
- * See https://spec.matrix.org/v1.12/client-server-api/#get_matrixclientv3room_keysversion
811
- *
812
- * @param http
813
- * @param version - the specific version of the backup info to fetch
814
- * @returns The key backup info or null if there is no backup.
815
- */
816
- export async function requestKeyBackupVersion(
817
- http: MatrixHttpApi<IHttpOpts & { onlyData: true }>,
818
- version?: string,
819
- ): Promise<KeyBackupInfo | null> {
820
- try {
821
- const path = version ? encodeUri("/room_keys/version/$version", { $version: version }) : "/room_keys/version";
822
- return await http.authedRequest<KeyBackupInfo>(Method.Get, path, undefined, undefined, {
823
- prefix: ClientPrefix.V3,
824
- });
825
- } catch (e) {
826
- if ((<MatrixError>e).errcode === "M_NOT_FOUND") {
827
- return null;
828
- } else {
829
- throw e;
830
- }
831
- }
832
- }
833
-
834
- /**
835
- * Checks if the provided decryption key matches the public key of the key backup info.
836
- *
837
- * @param decryptionKey - The decryption key to check.
838
- * @param keyBackupInfo - The key backup info to check against.
839
- * @returns `true` if the decryption key matches the key backup info, `false` otherwise.
840
- */
841
- export function decryptionKeyMatchesKeyBackupInfo(
842
- decryptionKey: RustSdkCryptoJs.BackupDecryptionKey,
843
- keyBackupInfo: KeyBackupInfo,
844
- ): boolean {
845
- const authData = <Curve25519AuthData>keyBackupInfo.auth_data;
846
- return authData.public_key === decryptionKey.megolmV1PublicKey.publicKeyBase64;
847
- }
848
-
849
- /**
850
- * Counts the total number of keys present in a key backup.
851
- * @param keyBackup - The key backup to count the keys from.
852
- * @returns The total number of keys in the backup.
853
- */
854
- function countKeysInBackup(keyBackup: KeyBackup): number {
855
- let count = 0;
856
- for (const { sessions } of Object.values(keyBackup.rooms)) {
857
- count += Object.keys(sessions).length;
858
- }
859
- return count;
860
- }
861
-
862
- export type RustBackupCryptoEvents =
863
- | CryptoEvent.KeyBackupStatus
864
- | CryptoEvent.KeyBackupSessionsRemaining
865
- | CryptoEvent.KeyBackupFailed
866
- | CryptoEvent.KeyBackupDecryptionKeyCached;
867
-
868
- export type RustBackupCryptoEventMap = {
869
- [CryptoEvent.KeyBackupStatus]: (enabled: boolean) => void;
870
- [CryptoEvent.KeyBackupSessionsRemaining]: (remaining: number) => void;
871
- [CryptoEvent.KeyBackupFailed]: (errCode: string) => void;
872
- [CryptoEvent.KeyBackupDecryptionKeyCached]: (version: string) => void;
873
- };
874
-
875
- /**
876
- * Response from GET `/room_keys/keys` endpoint.
877
- * See https://spec.matrix.org/latest/client-server-api/#get_matrixclientv3room_keyskeys
878
- */
879
- export interface KeyBackup {
880
- rooms: Record<string, { sessions: KeyBackupRoomSessions }>;
881
- }