@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,143 +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 { OlmMachine } from "@matrix-org/matrix-sdk-crypto-wasm";
18
-
19
- import { OutgoingRequest, OutgoingRequestProcessor } from "./OutgoingRequestProcessor.ts";
20
- import { Logger } from "../logger.ts";
21
- import { defer, IDeferred, logDuration } from "../utils.ts";
22
-
23
- /**
24
- * OutgoingRequestsManager: responsible for processing outgoing requests from the OlmMachine.
25
- * Ensure that only one loop is going on at once, and that the requests are processed in order.
26
- */
27
- export class OutgoingRequestsManager {
28
- /** whether {@link stop} has been called */
29
- private stopped = false;
30
-
31
- /** whether {@link outgoingRequestLoop} is currently running */
32
- private outgoingRequestLoopRunning = false;
33
-
34
- /**
35
- * If there are additional calls to doProcessOutgoingRequests() while there is a current call running
36
- * we need to remember in order to call `doProcessOutgoingRequests` again (as there could be new requests).
37
- *
38
- * If this is defined, it is an indication that we need to do another iteration; in this case the deferred
39
- * will resolve once that next iteration completes. If it is undefined, there have been no new calls
40
- * to `doProcessOutgoingRequests` since the current iteration started.
41
- */
42
- private nextLoopDeferred?: IDeferred<void>;
43
-
44
- public constructor(
45
- private readonly logger: Logger,
46
- private readonly olmMachine: OlmMachine,
47
- public readonly outgoingRequestProcessor: OutgoingRequestProcessor,
48
- ) {}
49
-
50
- /**
51
- * Shut down as soon as possible the current loop of outgoing requests processing.
52
- */
53
- public stop(): void {
54
- this.stopped = true;
55
- }
56
-
57
- /**
58
- * Process the OutgoingRequests from the OlmMachine.
59
- *
60
- * This should be called at the end of each sync, to process any OlmMachine OutgoingRequests created by the rust sdk.
61
- * In some cases if OutgoingRequests need to be sent immediately, this can be called directly.
62
- *
63
- * Calls to doProcessOutgoingRequests() are processed synchronously, one after the other, in order.
64
- * If doProcessOutgoingRequests() is called while another call is still being processed, it will be queued.
65
- * Multiple calls to doProcessOutgoingRequests() when a call is already processing will be batched together.
66
- */
67
- public doProcessOutgoingRequests(): Promise<void> {
68
- // Flag that we need at least one more iteration of the loop.
69
- //
70
- // It is important that we do this even if the loop is currently running. There is potential for a race whereby
71
- // a request is added to the queue *after* `OlmMachine.outgoingRequests` checks the queue, but *before* it
72
- // returns. In such a case, the item could sit there unnoticed for some time.
73
- //
74
- // In order to circumvent the race, we set a flag which tells the loop to go round once again even if the
75
- // queue appears to be empty.
76
- if (!this.nextLoopDeferred) {
77
- this.nextLoopDeferred = defer();
78
- }
79
-
80
- // ... and wait for it to complete.
81
- const result = this.nextLoopDeferred.promise;
82
-
83
- // set the loop going if it is not already.
84
- if (!this.outgoingRequestLoopRunning) {
85
- this.outgoingRequestLoop().catch((e) => {
86
- // this should not happen; outgoingRequestLoop should return any errors via `nextLoopDeferred`.
87
- /* istanbul ignore next */
88
- this.logger.error("Uncaught error in outgoing request loop", e);
89
- });
90
- }
91
- return result;
92
- }
93
-
94
- private async outgoingRequestLoop(): Promise<void> {
95
- /* istanbul ignore if */
96
- if (this.outgoingRequestLoopRunning) {
97
- throw new Error("Cannot run two outgoing request loops");
98
- }
99
- this.outgoingRequestLoopRunning = true;
100
- try {
101
- while (!this.stopped && this.nextLoopDeferred) {
102
- const deferred = this.nextLoopDeferred;
103
-
104
- // reset `nextLoopDeferred` so that any future calls to `doProcessOutgoingRequests` are queued
105
- // for another additional iteration.
106
- this.nextLoopDeferred = undefined;
107
-
108
- // make the requests and feed the results back to the `nextLoopDeferred`
109
- await this.processOutgoingRequests().then(deferred.resolve, deferred.reject);
110
- }
111
- } finally {
112
- this.outgoingRequestLoopRunning = false;
113
- }
114
-
115
- if (this.nextLoopDeferred) {
116
- // the loop was stopped, but there was a call to `doProcessOutgoingRequests`. Make sure that
117
- // we reject the promise in case anything is waiting for it.
118
- this.nextLoopDeferred.reject(new Error("OutgoingRequestsManager was stopped"));
119
- }
120
- }
121
-
122
- /**
123
- * Make a single request to `olmMachine.outgoingRequests` and do the corresponding requests.
124
- */
125
- private async processOutgoingRequests(): Promise<void> {
126
- if (this.stopped) return;
127
-
128
- const outgoingRequests: OutgoingRequest[] = await this.olmMachine.outgoingRequests();
129
-
130
- for (const request of outgoingRequests) {
131
- if (this.stopped) return;
132
- try {
133
- await logDuration(this.logger, `Make outgoing request ${request.type}`, async () => {
134
- await this.outgoingRequestProcessor.makeOutgoingRequest(request);
135
- });
136
- } catch (e) {
137
- // as part of the loop we silently ignore errors, but log them.
138
- // The rust sdk will retry the request later as it won't have been marked as sent.
139
- this.logger.error(`Failed to process outgoing request ${request.type}: ${e}`);
140
- }
141
- }
142
- }
143
- }
@@ -1,501 +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 * as RustSdkCryptoJs from "@matrix-org/matrix-sdk-crypto-wasm";
18
- import { OlmMachine } from "@matrix-org/matrix-sdk-crypto-wasm";
19
-
20
- import { Curve25519AuthData, KeyBackupInfo, KeyBackupSession } from "../crypto-api/keybackup.ts";
21
- import { CryptoEvent } from "../crypto-api/index.ts";
22
- import { Logger } from "../logger.ts";
23
- import { ClientPrefix, IHttpOpts, MatrixError, MatrixHttpApi, Method } from "../http-api/index.ts";
24
- import { RustBackupManager } from "./backup.ts";
25
- import { encodeUri, sleep } from "../utils.ts";
26
- import { BackupDecryptor } from "../common-crypto/CryptoBackend.ts";
27
-
28
- // The minimum time to wait between two retries in case of errors. To avoid hammering the server.
29
- const KEY_BACKUP_BACKOFF = 5000; // ms
30
-
31
- /**
32
- * Enumerates the different kind of errors that can occurs when downloading and importing a key from backup.
33
- */
34
- enum KeyDownloadErrorCode {
35
- /** The requested key is not in the backup. */
36
- MISSING_DECRYPTION_KEY = "MISSING_DECRYPTION_KEY",
37
- /** A network error occurred while trying to download the key from backup. */
38
- NETWORK_ERROR = "NETWORK_ERROR",
39
- /** The loop has been stopped. */
40
- STOPPED = "STOPPED",
41
- }
42
-
43
- class KeyDownloadError extends Error {
44
- public constructor(public readonly code: KeyDownloadErrorCode) {
45
- super(`Failed to get key from backup: ${code}`);
46
- this.name = "KeyDownloadError";
47
- }
48
- }
49
-
50
- class KeyDownloadRateLimitError extends Error {
51
- public constructor(public readonly retryMillis: number) {
52
- super(`Failed to get key from backup: rate limited`);
53
- this.name = "KeyDownloadRateLimitError";
54
- }
55
- }
56
-
57
- /** Details of a megolm session whose key we are trying to fetch. */
58
- type SessionInfo = { roomId: string; megolmSessionId: string };
59
-
60
- /** Holds the current backup decryptor and version that should be used.
61
- *
62
- * This is intended to be used as an immutable object (a new instance should be created if the configuration changes),
63
- * and some of the logic relies on that, so the properties are marked as `readonly`.
64
- */
65
- type Configuration = {
66
- readonly backupVersion: string;
67
- readonly decryptor: BackupDecryptor;
68
- };
69
-
70
- /**
71
- * Used when an 'unable to decrypt' error occurs. It attempts to download the key from the backup.
72
- *
73
- * The current backup API lacks pagination, which can lead to lengthy key retrieval times for large histories (several 10s of minutes).
74
- * To mitigate this, keys are downloaded on demand as decryption errors occurs.
75
- * While this approach may result in numerous requests, it improves user experience by reducing wait times for message decryption.
76
- *
77
- * The PerSessionKeyBackupDownloader is resistant to backup configuration changes: it will automatically resume querying when
78
- * the backup is configured correctly.
79
- */
80
- export class PerSessionKeyBackupDownloader {
81
- private stopped = false;
82
-
83
- /**
84
- * The version and decryption key to use with current backup if all set up correctly.
85
- *
86
- * Will not be set unless `hasConfigurationProblem` is `false`.
87
- */
88
- private configuration: Configuration | null = null;
89
-
90
- /** We remember when a session was requested and not found in backup to avoid query again too soon.
91
- * Map of session_id to timestamp */
92
- private sessionLastCheckAttemptedTime: Map<string, number> = new Map();
93
-
94
- /** The logger to use */
95
- private readonly logger: Logger;
96
-
97
- /** Whether the download loop is running. */
98
- private downloadLoopRunning = false;
99
-
100
- /** The list of requests that are queued. */
101
- private queuedRequests: SessionInfo[] = [];
102
-
103
- /** Remembers if we have a configuration problem. */
104
- private hasConfigurationProblem = false;
105
-
106
- /** The current server backup version check promise. To avoid doing a server call if one is in flight. */
107
- private currentBackupVersionCheck: Promise<Configuration | null> | null = null;
108
-
109
- /**
110
- * Creates a new instance of PerSessionKeyBackupDownloader.
111
- *
112
- * @param backupManager - The backup manager to use.
113
- * @param olmMachine - The olm machine to use.
114
- * @param http - The http instance to use.
115
- * @param logger - The logger to use.
116
- */
117
- public constructor(
118
- logger: Logger,
119
- private readonly olmMachine: OlmMachine,
120
- private readonly http: MatrixHttpApi<IHttpOpts & { onlyData: true }>,
121
- private readonly backupManager: RustBackupManager,
122
- ) {
123
- this.logger = logger.getChild("[PerSessionKeyBackupDownloader]");
124
-
125
- backupManager.on(CryptoEvent.KeyBackupStatus, this.onBackupStatusChanged);
126
- backupManager.on(CryptoEvent.KeyBackupFailed, this.onBackupStatusChanged);
127
- backupManager.on(CryptoEvent.KeyBackupDecryptionKeyCached, this.onBackupStatusChanged);
128
- }
129
-
130
- /**
131
- * Check if key download is successfully configured and active.
132
- *
133
- * @return `true` if key download is correctly configured and active; otherwise `false`.
134
- */
135
- public isKeyBackupDownloadConfigured(): boolean {
136
- return this.configuration !== null;
137
- }
138
-
139
- /**
140
- * Return the details of the latest backup on the server, when we last checked.
141
- *
142
- * This is just a convenience method to expose {@link RustBackupManager.getServerBackupInfo}.
143
- */
144
- public async getServerBackupInfo(): Promise<KeyBackupInfo | null | undefined> {
145
- return await this.backupManager.getServerBackupInfo();
146
- }
147
-
148
- /**
149
- * Called when a MissingRoomKey or UnknownMessageIndex decryption error is encountered.
150
- *
151
- * This will try to download the key from the backup if there is a trusted active backup.
152
- * In case of success the key will be imported and the onRoomKeysUpdated callback will be called
153
- * internally by the rust-sdk and decryption will be retried.
154
- *
155
- * @param roomId - The room ID of the room where the error occurred.
156
- * @param megolmSessionId - The megolm session ID that is missing.
157
- */
158
- public onDecryptionKeyMissingError(roomId: string, megolmSessionId: string): void {
159
- // Several messages encrypted with the same session may be decrypted at the same time,
160
- // so we need to be resistant and not query several time the same session.
161
- if (this.isAlreadyInQueue(roomId, megolmSessionId)) {
162
- // There is already a request queued for this session, no need to queue another one.
163
- this.logger.trace(`Not checking key backup for session ${megolmSessionId} as it is already queued`);
164
- return;
165
- }
166
-
167
- if (this.wasRequestedRecently(megolmSessionId)) {
168
- // We already tried to download this session recently and it was not in backup, no need to try again.
169
- this.logger.trace(
170
- `Not checking key backup for session ${megolmSessionId} as it was already requested recently`,
171
- );
172
- return;
173
- }
174
-
175
- // We always add the request to the queue, even if we have a configuration problem (can't access backup).
176
- // This is to make sure that if the configuration problem is resolved, we will try to download the key.
177
- // This will happen after an initial sync, at this point the backup will not yet be trusted and the decryption
178
- // key will not be available, but it will be just after the verification.
179
- // We don't need to persist it because currently on refresh the sdk will retry to decrypt the messages in error.
180
- this.queuedRequests.push({ roomId, megolmSessionId });
181
-
182
- // Start the download loop if it's not already running.
183
- this.downloadKeysLoop();
184
- }
185
-
186
- public stop(): void {
187
- this.stopped = true;
188
- this.backupManager.off(CryptoEvent.KeyBackupStatus, this.onBackupStatusChanged);
189
- this.backupManager.off(CryptoEvent.KeyBackupFailed, this.onBackupStatusChanged);
190
- this.backupManager.off(CryptoEvent.KeyBackupDecryptionKeyCached, this.onBackupStatusChanged);
191
- }
192
-
193
- /**
194
- * Called when the backup status changes (CryptoEvents)
195
- * This will trigger a check of the backup configuration.
196
- */
197
- private onBackupStatusChanged = (): void => {
198
- // we want to force check configuration, so we clear the current one.
199
- this.hasConfigurationProblem = false;
200
- this.configuration = null;
201
- this.getOrCreateBackupConfiguration().then((configuration) => {
202
- if (configuration) {
203
- // restart the download loop if it was stopped
204
- this.downloadKeysLoop();
205
- }
206
- });
207
- };
208
-
209
- /** Returns true if the megolm session is already queued for download. */
210
- private isAlreadyInQueue(roomId: string, megolmSessionId: string): boolean {
211
- return this.queuedRequests.some((info) => {
212
- return info.roomId == roomId && info.megolmSessionId == megolmSessionId;
213
- });
214
- }
215
-
216
- /**
217
- * Marks the session as not found in backup, to avoid retrying to soon for a key not in backup
218
- *
219
- * @param megolmSessionId - The megolm session ID that is missing.
220
- */
221
- private markAsNotFoundInBackup(megolmSessionId: string): void {
222
- const now = Date.now();
223
- this.sessionLastCheckAttemptedTime.set(megolmSessionId, now);
224
- // if too big make some cleaning to keep under control
225
- if (this.sessionLastCheckAttemptedTime.size > 100) {
226
- this.sessionLastCheckAttemptedTime = new Map(
227
- Array.from(this.sessionLastCheckAttemptedTime).filter((sid, ts) => {
228
- return Math.max(now - ts, 0) < KEY_BACKUP_BACKOFF;
229
- }),
230
- );
231
- }
232
- }
233
-
234
- /** Returns true if the session was requested recently. */
235
- private wasRequestedRecently(megolmSessionId: string): boolean {
236
- const lastCheck = this.sessionLastCheckAttemptedTime.get(megolmSessionId);
237
- if (!lastCheck) return false;
238
- return Math.max(Date.now() - lastCheck, 0) < KEY_BACKUP_BACKOFF;
239
- }
240
-
241
- private async getBackupDecryptionKey(): Promise<RustSdkCryptoJs.BackupKeys | null> {
242
- try {
243
- return await this.olmMachine.getBackupKeys();
244
- } catch {
245
- return null;
246
- }
247
- }
248
-
249
- /**
250
- * Requests a key from the server side backup.
251
- *
252
- * @param version - The backup version to use.
253
- * @param roomId - The room ID of the room where the error occurred.
254
- * @param sessionId - The megolm session ID that is missing.
255
- */
256
- private async requestRoomKeyFromBackup(
257
- version: string,
258
- roomId: string,
259
- sessionId: string,
260
- ): Promise<KeyBackupSession> {
261
- const path = encodeUri("/room_keys/keys/$roomId/$sessionId", {
262
- $roomId: roomId,
263
- $sessionId: sessionId,
264
- });
265
-
266
- return await this.http.authedRequest<KeyBackupSession>(Method.Get, path, { version }, undefined, {
267
- prefix: ClientPrefix.V3,
268
- });
269
- }
270
-
271
- private async downloadKeysLoop(): Promise<void> {
272
- if (this.downloadLoopRunning) return;
273
-
274
- // If we have a configuration problem, we don't want to try to download.
275
- // If any configuration change is detected, we will retry and restart the loop.
276
- if (this.hasConfigurationProblem) return;
277
-
278
- this.downloadLoopRunning = true;
279
-
280
- try {
281
- while (this.queuedRequests.length > 0) {
282
- // we just peek the first one without removing it, so if a new request for same key comes in while we're
283
- // processing this one, it won't queue another request.
284
- const request = this.queuedRequests[0];
285
- try {
286
- // The backup could have changed between the time we queued the request and now, so we need to check
287
- const configuration = await this.getOrCreateBackupConfiguration();
288
- if (!configuration) {
289
- // Backup is not configured correctly, so stop the loop.
290
- this.downloadLoopRunning = false;
291
- return;
292
- }
293
-
294
- const result = await this.queryKeyBackup(request.roomId, request.megolmSessionId, configuration);
295
-
296
- if (this.stopped) {
297
- return;
298
- }
299
- // We got the encrypted key from backup, let's try to decrypt and import it.
300
- try {
301
- await this.decryptAndImport(request, result, configuration);
302
- } catch (e) {
303
- this.logger.error(
304
- `Error while decrypting and importing key backup for session ${request.megolmSessionId}`,
305
- e,
306
- );
307
- }
308
- // now remove the request from the queue as we've processed it.
309
- this.queuedRequests.shift();
310
- } catch (err) {
311
- if (err instanceof KeyDownloadError) {
312
- switch (err.code) {
313
- case KeyDownloadErrorCode.MISSING_DECRYPTION_KEY:
314
- this.markAsNotFoundInBackup(request.megolmSessionId);
315
- // continue for next one
316
- this.queuedRequests.shift();
317
- break;
318
- case KeyDownloadErrorCode.NETWORK_ERROR:
319
- // We don't want to hammer if there is a problem, so wait a bit.
320
- await sleep(KEY_BACKUP_BACKOFF);
321
- break;
322
- case KeyDownloadErrorCode.STOPPED:
323
- // If the downloader was stopped, we don't want to retry.
324
- this.downloadLoopRunning = false;
325
- return;
326
- }
327
- } else if (err instanceof KeyDownloadRateLimitError) {
328
- // we want to retry after the backoff time
329
- await sleep(err.retryMillis);
330
- }
331
- }
332
- }
333
- } finally {
334
- // all pending request have been processed, we can stop the loop.
335
- this.downloadLoopRunning = false;
336
- }
337
- }
338
-
339
- /**
340
- * Query the backup for a key.
341
- *
342
- * @param targetRoomId - ID of the room that the session is used in.
343
- * @param targetSessionId - ID of the session for which to check backup.
344
- * @param configuration - The backup configuration to use.
345
- */
346
- private async queryKeyBackup(
347
- targetRoomId: string,
348
- targetSessionId: string,
349
- configuration: Configuration,
350
- ): Promise<KeyBackupSession> {
351
- this.logger.debug(`Checking key backup for session ${targetSessionId}`);
352
- if (this.stopped) throw new KeyDownloadError(KeyDownloadErrorCode.STOPPED);
353
- try {
354
- const res = await this.requestRoomKeyFromBackup(configuration.backupVersion, targetRoomId, targetSessionId);
355
- this.logger.debug(`Got key from backup for sessionId:${targetSessionId}`);
356
- return res;
357
- } catch (e) {
358
- if (this.stopped) throw new KeyDownloadError(KeyDownloadErrorCode.STOPPED);
359
-
360
- this.logger.info(`No luck requesting key backup for session ${targetSessionId}: ${e}`);
361
- if (e instanceof MatrixError) {
362
- const errCode = e.data.errcode;
363
- if (errCode == "M_NOT_FOUND") {
364
- // Unfortunately the spec doesn't give us a way to differentiate between a missing key and a wrong version.
365
- // Synapse will return:
366
- // - "error": "Unknown backup version" if the version is wrong.
367
- // - "error": "No room_keys found" if the key is missing.
368
- // It's useful to know if the key is missing or if the version is wrong.
369
- // As it's not spec'ed, we fall back on considering the key is not in backup.
370
- // Notice that this request will be lost if instead the backup got out of sync (updated from other session).
371
- throw new KeyDownloadError(KeyDownloadErrorCode.MISSING_DECRYPTION_KEY);
372
- }
373
- if (e.isRateLimitError()) {
374
- let waitTime: number | undefined;
375
- try {
376
- waitTime = e.getRetryAfterMs() ?? undefined;
377
- } catch (error) {
378
- this.logger.warn("Error while retrieving a rate-limit retry delay", error);
379
- }
380
- if (waitTime && waitTime > 0) {
381
- this.logger.info(`Rate limited by server, waiting ${waitTime}ms`);
382
- }
383
- throw new KeyDownloadRateLimitError(waitTime ?? KEY_BACKUP_BACKOFF);
384
- }
385
- }
386
- throw new KeyDownloadError(KeyDownloadErrorCode.NETWORK_ERROR);
387
- }
388
- }
389
-
390
- private async decryptAndImport(
391
- sessionInfo: SessionInfo,
392
- data: KeyBackupSession,
393
- configuration: Configuration,
394
- ): Promise<void> {
395
- const sessionsToImport: Record<string, KeyBackupSession> = { [sessionInfo.megolmSessionId]: data };
396
-
397
- const keys = await configuration!.decryptor.decryptSessions(sessionsToImport);
398
- for (const k of keys) {
399
- k.room_id = sessionInfo.roomId;
400
- }
401
- await this.backupManager.importBackedUpRoomKeys(keys, configuration.backupVersion);
402
- }
403
-
404
- /**
405
- * Gets the current backup configuration or create one if it doesn't exist.
406
- *
407
- * When a valid configuration is found it is cached and returned for subsequent calls.
408
- * Otherwise, if a check is forced or a check has not yet been done, a new check is done.
409
- *
410
- * @returns The backup configuration to use or null if there is a configuration problem.
411
- */
412
- private async getOrCreateBackupConfiguration(): Promise<Configuration | null> {
413
- if (this.configuration) {
414
- return this.configuration;
415
- }
416
-
417
- // We already tried to check the configuration and it failed.
418
- // We don't want to try again immediately, we will retry if a configuration change is detected.
419
- if (this.hasConfigurationProblem) {
420
- return null;
421
- }
422
-
423
- // This method can be called rapidly by several emitted CryptoEvent, so we need to make sure that we don't
424
- // query the server several times.
425
- if (this.currentBackupVersionCheck != null) {
426
- this.logger.debug(`Already checking server version, use current promise`);
427
- return await this.currentBackupVersionCheck;
428
- }
429
-
430
- this.currentBackupVersionCheck = this.internalCheckFromServer();
431
- try {
432
- return await this.currentBackupVersionCheck;
433
- } finally {
434
- this.currentBackupVersionCheck = null;
435
- }
436
- }
437
-
438
- private async internalCheckFromServer(): Promise<Configuration | null> {
439
- let currentServerVersion = null;
440
- try {
441
- currentServerVersion = await this.backupManager.getServerBackupInfo();
442
- } catch (e) {
443
- this.logger.debug(`Backup: error while checking server version: ${e}`);
444
- this.hasConfigurationProblem = true;
445
- return null;
446
- }
447
- this.logger.debug(`Got current backup version from server: ${currentServerVersion?.version}`);
448
-
449
- if (currentServerVersion?.algorithm != "m.megolm_backup.v1.curve25519-aes-sha2") {
450
- this.logger.info(`Unsupported algorithm ${currentServerVersion?.algorithm}`);
451
- this.hasConfigurationProblem = true;
452
- return null;
453
- }
454
-
455
- if (!currentServerVersion?.version) {
456
- this.logger.info(`No current key backup`);
457
- this.hasConfigurationProblem = true;
458
- return null;
459
- }
460
-
461
- const activeVersion = await this.backupManager.getActiveBackupVersion();
462
- if (activeVersion == null || currentServerVersion.version != activeVersion) {
463
- // Either the current backup version on server side is not trusted, or it is out of sync with the active version on the client side.
464
- this.logger.info(
465
- `The current backup version on the server (${currentServerVersion.version}) is not trusted. Version we are currently backing up to: ${activeVersion}`,
466
- );
467
- this.hasConfigurationProblem = true;
468
- return null;
469
- }
470
-
471
- const backupKeys = await this.getBackupDecryptionKey();
472
- if (!backupKeys?.decryptionKey) {
473
- this.logger.debug(`Not checking key backup for session (no decryption key)`);
474
- this.hasConfigurationProblem = true;
475
- return null;
476
- }
477
-
478
- if (activeVersion != backupKeys.backupVersion) {
479
- this.logger.debug(
480
- `Version for which we have a decryption key (${backupKeys.backupVersion}) doesn't match the version we are backing up to (${activeVersion})`,
481
- );
482
- this.hasConfigurationProblem = true;
483
- return null;
484
- }
485
-
486
- const authData = currentServerVersion.auth_data as Curve25519AuthData;
487
- if (authData.public_key != backupKeys.decryptionKey.megolmV1PublicKey.publicKeyBase64) {
488
- this.logger.debug(`Key backup on server does not match our decryption key`);
489
- this.hasConfigurationProblem = true;
490
- return null;
491
- }
492
-
493
- const backupDecryptor = this.backupManager.createBackupDecryptor(backupKeys.decryptionKey);
494
- this.hasConfigurationProblem = false;
495
- this.configuration = {
496
- decryptor: backupDecryptor,
497
- backupVersion: activeVersion,
498
- };
499
- return this.configuration;
500
- }
501
- }