@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,1250 +0,0 @@
1
- /*
2
- Copyright 2017 - 2021 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 { Logger, logger } from "../../logger.ts";
18
- import { deepCompare } from "../../utils.ts";
19
- import {
20
- CryptoStore,
21
- IDeviceData,
22
- IProblem,
23
- ISession,
24
- SessionExtended,
25
- ISessionInfo,
26
- IWithheld,
27
- MigrationState,
28
- Mode,
29
- OutgoingRoomKeyRequest,
30
- ParkedSharedHistory,
31
- SecretStorePrivateKeys,
32
- SESSION_BATCH_SIZE,
33
- ACCOUNT_OBJECT_KEY_MIGRATION_STATE,
34
- } from "./base.ts";
35
- import { IRoomKeyRequestBody, IRoomKeyRequestRecipient } from "../index.ts";
36
- import { IOlmDevice } from "../algorithms/megolm.ts";
37
- import { IRoomEncryption } from "../RoomList.ts";
38
- import { InboundGroupSessionData } from "../OlmDevice.ts";
39
- import { IndexedDBCryptoStore } from "./indexeddb-crypto-store.ts";
40
- import { CrossSigningKeyInfo } from "../../crypto-api/index.ts";
41
-
42
- const PROFILE_TRANSACTIONS = false;
43
-
44
- /**
45
- * Implementation of a CryptoStore which is backed by an existing
46
- * IndexedDB connection. Generally you want IndexedDBCryptoStore
47
- * which connects to the database and defers to one of these.
48
- *
49
- * @internal
50
- */
51
- export class Backend implements CryptoStore {
52
- private nextTxnId = 0;
53
-
54
- /**
55
- */
56
- public constructor(private db: IDBDatabase) {
57
- // make sure we close the db on `onversionchange` - otherwise
58
- // attempts to delete the database will block (and subsequent
59
- // attempts to re-create it will also block).
60
- db.onversionchange = (): void => {
61
- logger.log(`versionchange for indexeddb ${this.db.name}: closing`);
62
- db.close();
63
- };
64
- }
65
-
66
- public async containsData(): Promise<boolean> {
67
- throw Error("Not implemented for Backend");
68
- }
69
-
70
- public async startup(): Promise<CryptoStore> {
71
- // No work to do, as the startup is done by the caller (e.g IndexedDBCryptoStore)
72
- // by passing us a ready IDBDatabase instance
73
- return this;
74
- }
75
-
76
- public async deleteAllData(): Promise<void> {
77
- throw Error("This is not implemented, call IDBFactory::deleteDatabase(dbName) instead.");
78
- }
79
-
80
- /**
81
- * Get data on how much of the libolm to Rust Crypto migration has been done.
82
- *
83
- * Implementation of {@link CryptoStore.getMigrationState}.
84
- */
85
- public async getMigrationState(): Promise<MigrationState> {
86
- let migrationState = MigrationState.NOT_STARTED;
87
- await this.doTxn("readonly", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {
88
- const objectStore = txn.objectStore(IndexedDBCryptoStore.STORE_ACCOUNT);
89
- const getReq = objectStore.get(ACCOUNT_OBJECT_KEY_MIGRATION_STATE);
90
- getReq.onsuccess = (): void => {
91
- migrationState = getReq.result ?? MigrationState.NOT_STARTED;
92
- };
93
- });
94
- return migrationState;
95
- }
96
-
97
- /**
98
- * Set data on how much of the libolm to Rust Crypto migration has been done.
99
- *
100
- * Implementation of {@link CryptoStore.setMigrationState}.
101
- */
102
- public async setMigrationState(migrationState: MigrationState): Promise<void> {
103
- await this.doTxn("readwrite", [IndexedDBCryptoStore.STORE_ACCOUNT], (txn) => {
104
- const objectStore = txn.objectStore(IndexedDBCryptoStore.STORE_ACCOUNT);
105
- objectStore.put(migrationState, ACCOUNT_OBJECT_KEY_MIGRATION_STATE);
106
- });
107
- }
108
-
109
- /**
110
- * Look for an existing outgoing room key request, and if none is found,
111
- * add a new one
112
- *
113
- *
114
- * @returns resolves to
115
- * {@link OutgoingRoomKeyRequest}: either the
116
- * same instance as passed in, or the existing one.
117
- */
118
- public getOrAddOutgoingRoomKeyRequest(request: OutgoingRoomKeyRequest): Promise<OutgoingRoomKeyRequest> {
119
- const requestBody = request.requestBody;
120
-
121
- return new Promise((resolve, reject) => {
122
- const txn = this.db.transaction("outgoingRoomKeyRequests", "readwrite");
123
- txn.onerror = reject;
124
-
125
- // first see if we already have an entry for this request.
126
- this._getOutgoingRoomKeyRequest(txn, requestBody, (existing) => {
127
- if (existing) {
128
- // this entry matches the request - return it.
129
- logger.log(
130
- `already have key request outstanding for ` +
131
- `${requestBody.room_id} / ${requestBody.session_id}: ` +
132
- `not sending another`,
133
- );
134
- resolve(existing);
135
- return;
136
- }
137
-
138
- // we got to the end of the list without finding a match
139
- // - add the new request.
140
- logger.log(`enqueueing key request for ${requestBody.room_id} / ` + requestBody.session_id);
141
- txn.oncomplete = (): void => {
142
- resolve(request);
143
- };
144
- const store = txn.objectStore("outgoingRoomKeyRequests");
145
- store.add(request);
146
- });
147
- });
148
- }
149
-
150
- /**
151
- * Look for an existing room key request
152
- *
153
- * @param requestBody - existing request to look for
154
- *
155
- * @returns resolves to the matching
156
- * {@link OutgoingRoomKeyRequest}, or null if
157
- * not found
158
- */
159
- public getOutgoingRoomKeyRequest(requestBody: IRoomKeyRequestBody): Promise<OutgoingRoomKeyRequest | null> {
160
- return new Promise((resolve, reject) => {
161
- const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly");
162
- txn.onerror = reject;
163
-
164
- this._getOutgoingRoomKeyRequest(txn, requestBody, (existing) => {
165
- resolve(existing);
166
- });
167
- });
168
- }
169
-
170
- /**
171
- * look for an existing room key request in the db
172
- *
173
- * @internal
174
- * @param txn - database transaction
175
- * @param requestBody - existing request to look for
176
- * @param callback - function to call with the results of the
177
- * search. Either passed a matching
178
- * {@link OutgoingRoomKeyRequest}, or null if
179
- * not found.
180
- */
181
- // eslint-disable-next-line @typescript-eslint/naming-convention
182
- private _getOutgoingRoomKeyRequest(
183
- txn: IDBTransaction,
184
- requestBody: IRoomKeyRequestBody,
185
- callback: (req: OutgoingRoomKeyRequest | null) => void,
186
- ): void {
187
- const store = txn.objectStore("outgoingRoomKeyRequests");
188
-
189
- const idx = store.index("session");
190
- const cursorReq = idx.openCursor([requestBody.room_id, requestBody.session_id]);
191
-
192
- cursorReq.onsuccess = (): void => {
193
- const cursor = cursorReq.result;
194
- if (!cursor) {
195
- // no match found
196
- callback(null);
197
- return;
198
- }
199
-
200
- const existing = cursor.value;
201
-
202
- if (deepCompare(existing.requestBody, requestBody)) {
203
- // got a match
204
- callback(existing);
205
- return;
206
- }
207
-
208
- // look at the next entry in the index
209
- cursor.continue();
210
- };
211
- }
212
-
213
- /**
214
- * Look for room key requests by state
215
- *
216
- * @param wantedStates - list of acceptable states
217
- *
218
- * @returns resolves to the a
219
- * {@link OutgoingRoomKeyRequest}, or null if
220
- * there are no pending requests in those states. If there are multiple
221
- * requests in those states, an arbitrary one is chosen.
222
- */
223
- public getOutgoingRoomKeyRequestByState(wantedStates: number[]): Promise<OutgoingRoomKeyRequest | null> {
224
- if (wantedStates.length === 0) {
225
- return Promise.resolve(null);
226
- }
227
-
228
- // this is a bit tortuous because we need to make sure we do the lookup
229
- // in a single transaction, to avoid having a race with the insertion
230
- // code.
231
-
232
- // index into the wantedStates array
233
- let stateIndex = 0;
234
- let result: OutgoingRoomKeyRequest;
235
-
236
- function onsuccess(this: IDBRequest<IDBCursorWithValue | null>): void {
237
- const cursor = this.result;
238
- if (cursor) {
239
- // got a match
240
- result = cursor.value;
241
- return;
242
- }
243
-
244
- // try the next state in the list
245
- stateIndex++;
246
- if (stateIndex >= wantedStates.length) {
247
- // no matches
248
- return;
249
- }
250
-
251
- const wantedState = wantedStates[stateIndex];
252
- const cursorReq = (this.source as IDBIndex).openCursor(wantedState);
253
- cursorReq.onsuccess = onsuccess;
254
- }
255
-
256
- const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly");
257
- const store = txn.objectStore("outgoingRoomKeyRequests");
258
-
259
- const wantedState = wantedStates[stateIndex];
260
- const cursorReq = store.index("state").openCursor(wantedState);
261
- cursorReq.onsuccess = onsuccess;
262
-
263
- return promiseifyTxn(txn).then(() => result);
264
- }
265
-
266
- /**
267
- *
268
- * @returns All elements in a given state
269
- */
270
- public getAllOutgoingRoomKeyRequestsByState(wantedState: number): Promise<OutgoingRoomKeyRequest[]> {
271
- return new Promise((resolve, reject) => {
272
- const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly");
273
- const store = txn.objectStore("outgoingRoomKeyRequests");
274
- const index = store.index("state");
275
- const request = index.getAll(wantedState);
276
-
277
- request.onsuccess = (): void => resolve(request.result);
278
- request.onerror = (): void => reject(request.error);
279
- });
280
- }
281
-
282
- public getOutgoingRoomKeyRequestsByTarget(
283
- userId: string,
284
- deviceId: string,
285
- wantedStates: number[],
286
- ): Promise<OutgoingRoomKeyRequest[]> {
287
- let stateIndex = 0;
288
- const results: OutgoingRoomKeyRequest[] = [];
289
-
290
- function onsuccess(this: IDBRequest<IDBCursorWithValue | null>): void {
291
- const cursor = this.result;
292
- if (cursor) {
293
- const keyReq = cursor.value;
294
- if (
295
- keyReq.recipients.some(
296
- (recipient: IRoomKeyRequestRecipient) =>
297
- recipient.userId === userId && recipient.deviceId === deviceId,
298
- )
299
- ) {
300
- results.push(keyReq);
301
- }
302
- cursor.continue();
303
- } else {
304
- // try the next state in the list
305
- stateIndex++;
306
- if (stateIndex >= wantedStates.length) {
307
- // no matches
308
- return;
309
- }
310
-
311
- const wantedState = wantedStates[stateIndex];
312
- const cursorReq = (this.source as IDBIndex).openCursor(wantedState);
313
- cursorReq.onsuccess = onsuccess;
314
- }
315
- }
316
-
317
- const txn = this.db.transaction("outgoingRoomKeyRequests", "readonly");
318
- const store = txn.objectStore("outgoingRoomKeyRequests");
319
-
320
- const wantedState = wantedStates[stateIndex];
321
- const cursorReq = store.index("state").openCursor(wantedState);
322
- cursorReq.onsuccess = onsuccess;
323
-
324
- return promiseifyTxn(txn).then(() => results);
325
- }
326
-
327
- /**
328
- * Look for an existing room key request by id and state, and update it if
329
- * found
330
- *
331
- * @param requestId - ID of request to update
332
- * @param expectedState - state we expect to find the request in
333
- * @param updates - name/value map of updates to apply
334
- *
335
- * @returns resolves to
336
- * {@link OutgoingRoomKeyRequest}
337
- * updated request, or null if no matching row was found
338
- */
339
- public updateOutgoingRoomKeyRequest(
340
- requestId: string,
341
- expectedState: number,
342
- updates: Partial<OutgoingRoomKeyRequest>,
343
- ): Promise<OutgoingRoomKeyRequest | null> {
344
- let result: OutgoingRoomKeyRequest | null = null;
345
-
346
- function onsuccess(this: IDBRequest<IDBCursorWithValue | null>): void {
347
- const cursor = this.result;
348
- if (!cursor) {
349
- return;
350
- }
351
- const data = cursor.value;
352
- if (data.state != expectedState) {
353
- logger.warn(
354
- `Cannot update room key request from ${expectedState} ` +
355
- `as it was already updated to ${data.state}`,
356
- );
357
- return;
358
- }
359
- Object.assign(data, updates);
360
- cursor.update(data);
361
- result = data;
362
- }
363
-
364
- const txn = this.db.transaction("outgoingRoomKeyRequests", "readwrite");
365
- const cursorReq = txn.objectStore("outgoingRoomKeyRequests").openCursor(requestId);
366
- cursorReq.onsuccess = onsuccess;
367
- return promiseifyTxn(txn).then(() => result);
368
- }
369
-
370
- /**
371
- * Look for an existing room key request by id and state, and delete it if
372
- * found
373
- *
374
- * @param requestId - ID of request to update
375
- * @param expectedState - state we expect to find the request in
376
- *
377
- * @returns resolves once the operation is completed
378
- */
379
- public deleteOutgoingRoomKeyRequest(
380
- requestId: string,
381
- expectedState: number,
382
- ): Promise<OutgoingRoomKeyRequest | null> {
383
- const txn = this.db.transaction("outgoingRoomKeyRequests", "readwrite");
384
- const cursorReq = txn.objectStore("outgoingRoomKeyRequests").openCursor(requestId);
385
- cursorReq.onsuccess = (): void => {
386
- const cursor = cursorReq.result;
387
- if (!cursor) {
388
- return;
389
- }
390
- const data = cursor.value;
391
- if (data.state != expectedState) {
392
- logger.warn(`Cannot delete room key request in state ${data.state} ` + `(expected ${expectedState})`);
393
- return;
394
- }
395
- cursor.delete();
396
- };
397
- return promiseifyTxn<OutgoingRoomKeyRequest | null>(txn);
398
- }
399
-
400
- // Olm Account
401
-
402
- public getAccount(txn: IDBTransaction, func: (accountPickle: string | null) => void): void {
403
- const objectStore = txn.objectStore("account");
404
- const getReq = objectStore.get("-");
405
- getReq.onsuccess = function (): void {
406
- try {
407
- func(getReq.result || null);
408
- } catch (e) {
409
- abortWithException(txn, <Error>e);
410
- }
411
- };
412
- }
413
-
414
- public storeAccount(txn: IDBTransaction, accountPickle: string): void {
415
- const objectStore = txn.objectStore("account");
416
- objectStore.put(accountPickle, "-");
417
- }
418
-
419
- public getCrossSigningKeys(
420
- txn: IDBTransaction,
421
- func: (keys: Record<string, CrossSigningKeyInfo> | null) => void,
422
- ): void {
423
- const objectStore = txn.objectStore("account");
424
- const getReq = objectStore.get("crossSigningKeys");
425
- getReq.onsuccess = function (): void {
426
- try {
427
- func(getReq.result || null);
428
- } catch (e) {
429
- abortWithException(txn, <Error>e);
430
- }
431
- };
432
- }
433
-
434
- public getSecretStorePrivateKey<K extends keyof SecretStorePrivateKeys>(
435
- txn: IDBTransaction,
436
- func: (key: SecretStorePrivateKeys[K] | null) => void,
437
- type: K,
438
- ): void {
439
- const objectStore = txn.objectStore("account");
440
- const getReq = objectStore.get(`ssss_cache:${type}`);
441
- getReq.onsuccess = function (): void {
442
- try {
443
- func(getReq.result || null);
444
- } catch (e) {
445
- abortWithException(txn, <Error>e);
446
- }
447
- };
448
- }
449
-
450
- public storeCrossSigningKeys(txn: IDBTransaction, keys: Record<string, CrossSigningKeyInfo>): void {
451
- const objectStore = txn.objectStore("account");
452
- objectStore.put(keys, "crossSigningKeys");
453
- }
454
-
455
- public storeSecretStorePrivateKey<K extends keyof SecretStorePrivateKeys>(
456
- txn: IDBTransaction,
457
- type: K,
458
- key: SecretStorePrivateKeys[K],
459
- ): void {
460
- const objectStore = txn.objectStore("account");
461
- objectStore.put(key, `ssss_cache:${type}`);
462
- }
463
-
464
- // Olm Sessions
465
-
466
- public countEndToEndSessions(txn: IDBTransaction, func: (count: number) => void): void {
467
- const objectStore = txn.objectStore("sessions");
468
- const countReq = objectStore.count();
469
- countReq.onsuccess = function (): void {
470
- try {
471
- func(countReq.result);
472
- } catch (e) {
473
- abortWithException(txn, <Error>e);
474
- }
475
- };
476
- }
477
-
478
- public getEndToEndSessions(
479
- deviceKey: string,
480
- txn: IDBTransaction,
481
- func: (sessions: { [sessionId: string]: ISessionInfo }) => void,
482
- ): void {
483
- const objectStore = txn.objectStore("sessions");
484
- const idx = objectStore.index("deviceKey");
485
- const getReq = idx.openCursor(deviceKey);
486
- const results: Parameters<Parameters<Backend["getEndToEndSessions"]>[2]>[0] = {};
487
- getReq.onsuccess = function (): void {
488
- const cursor = getReq.result;
489
- if (cursor) {
490
- results[cursor.value.sessionId] = {
491
- session: cursor.value.session,
492
- lastReceivedMessageTs: cursor.value.lastReceivedMessageTs,
493
- };
494
- cursor.continue();
495
- } else {
496
- try {
497
- func(results);
498
- } catch (e) {
499
- abortWithException(txn, <Error>e);
500
- }
501
- }
502
- };
503
- }
504
-
505
- public getEndToEndSession(
506
- deviceKey: string,
507
- sessionId: string,
508
- txn: IDBTransaction,
509
- func: (session: ISessionInfo | null) => void,
510
- ): void {
511
- const objectStore = txn.objectStore("sessions");
512
- const getReq = objectStore.get([deviceKey, sessionId]);
513
- getReq.onsuccess = function (): void {
514
- try {
515
- if (getReq.result) {
516
- func({
517
- session: getReq.result.session,
518
- lastReceivedMessageTs: getReq.result.lastReceivedMessageTs,
519
- });
520
- } else {
521
- func(null);
522
- }
523
- } catch (e) {
524
- abortWithException(txn, <Error>e);
525
- }
526
- };
527
- }
528
-
529
- public getAllEndToEndSessions(txn: IDBTransaction, func: (session: ISessionInfo | null) => void): void {
530
- const objectStore = txn.objectStore("sessions");
531
- const getReq = objectStore.openCursor();
532
- getReq.onsuccess = function (): void {
533
- try {
534
- const cursor = getReq.result;
535
- if (cursor) {
536
- func(cursor.value);
537
- cursor.continue();
538
- } else {
539
- func(null);
540
- }
541
- } catch (e) {
542
- abortWithException(txn, <Error>e);
543
- }
544
- };
545
- }
546
-
547
- public storeEndToEndSession(
548
- deviceKey: string,
549
- sessionId: string,
550
- sessionInfo: ISessionInfo,
551
- txn: IDBTransaction,
552
- ): void {
553
- const objectStore = txn.objectStore("sessions");
554
- objectStore.put({
555
- deviceKey,
556
- sessionId,
557
- session: sessionInfo.session,
558
- lastReceivedMessageTs: sessionInfo.lastReceivedMessageTs,
559
- });
560
- }
561
-
562
- public async storeEndToEndSessionProblem(deviceKey: string, type: string, fixed: boolean): Promise<void> {
563
- const txn = this.db.transaction("session_problems", "readwrite");
564
- const objectStore = txn.objectStore("session_problems");
565
- objectStore.put({
566
- deviceKey,
567
- type,
568
- fixed,
569
- time: Date.now(),
570
- });
571
- await promiseifyTxn(txn);
572
- }
573
-
574
- public async getEndToEndSessionProblem(deviceKey: string, timestamp: number): Promise<IProblem | null> {
575
- let result: IProblem | null = null;
576
- const txn = this.db.transaction("session_problems", "readwrite");
577
- const objectStore = txn.objectStore("session_problems");
578
- const index = objectStore.index("deviceKey");
579
- const req = index.getAll(deviceKey);
580
- req.onsuccess = (): void => {
581
- const problems = req.result;
582
- if (!problems.length) {
583
- result = null;
584
- return;
585
- }
586
- problems.sort((a, b) => {
587
- return a.time - b.time;
588
- });
589
- const lastProblem = problems[problems.length - 1];
590
- for (const problem of problems) {
591
- if (problem.time > timestamp) {
592
- result = Object.assign({}, problem, { fixed: lastProblem.fixed });
593
- return;
594
- }
595
- }
596
- if (lastProblem.fixed) {
597
- result = null;
598
- } else {
599
- result = lastProblem;
600
- }
601
- };
602
- await promiseifyTxn(txn);
603
- return result;
604
- }
605
-
606
- // FIXME: we should probably prune this when devices get deleted
607
- public async filterOutNotifiedErrorDevices(devices: IOlmDevice[]): Promise<IOlmDevice[]> {
608
- const txn = this.db.transaction("notified_error_devices", "readwrite");
609
- const objectStore = txn.objectStore("notified_error_devices");
610
-
611
- const ret: IOlmDevice[] = [];
612
-
613
- await Promise.all(
614
- devices.map((device) => {
615
- return new Promise<void>((resolve) => {
616
- const { userId, deviceInfo } = device;
617
- const getReq = objectStore.get([userId, deviceInfo.deviceId]);
618
- getReq.onsuccess = function (): void {
619
- if (!getReq.result) {
620
- objectStore.put({ userId, deviceId: deviceInfo.deviceId });
621
- ret.push(device);
622
- }
623
- resolve();
624
- };
625
- });
626
- }),
627
- );
628
-
629
- return ret;
630
- }
631
-
632
- /**
633
- * Fetch a batch of Olm sessions from the database.
634
- *
635
- * Implementation of {@link CryptoStore.getEndToEndSessionsBatch}.
636
- */
637
- public async getEndToEndSessionsBatch(): Promise<null | ISessionInfo[]> {
638
- const result: ISessionInfo[] = [];
639
- await this.doTxn("readonly", [IndexedDBCryptoStore.STORE_SESSIONS], (txn) => {
640
- const objectStore = txn.objectStore(IndexedDBCryptoStore.STORE_SESSIONS);
641
- const getReq = objectStore.openCursor();
642
- getReq.onsuccess = function (): void {
643
- try {
644
- const cursor = getReq.result;
645
- if (cursor) {
646
- result.push(cursor.value);
647
- if (result.length < SESSION_BATCH_SIZE) {
648
- cursor.continue();
649
- }
650
- }
651
- } catch (e) {
652
- abortWithException(txn, <Error>e);
653
- }
654
- };
655
- });
656
-
657
- if (result.length === 0) {
658
- // No sessions left.
659
- return null;
660
- }
661
-
662
- return result;
663
- }
664
-
665
- /**
666
- * Delete a batch of Olm sessions from the database.
667
- *
668
- * Implementation of {@link CryptoStore.deleteEndToEndSessionsBatch}.
669
- *
670
- * @internal
671
- */
672
- public async deleteEndToEndSessionsBatch(sessions: { deviceKey: string; sessionId: string }[]): Promise<void> {
673
- await this.doTxn("readwrite", [IndexedDBCryptoStore.STORE_SESSIONS], async (txn) => {
674
- try {
675
- const objectStore = txn.objectStore(IndexedDBCryptoStore.STORE_SESSIONS);
676
- for (const { deviceKey, sessionId } of sessions) {
677
- const req = objectStore.delete([deviceKey, sessionId]);
678
- await new Promise((resolve) => {
679
- req.onsuccess = resolve;
680
- });
681
- }
682
- } catch (e) {
683
- abortWithException(txn, <Error>e);
684
- }
685
- });
686
- }
687
-
688
- // Inbound group sessions
689
-
690
- public getEndToEndInboundGroupSession(
691
- senderCurve25519Key: string,
692
- sessionId: string,
693
- txn: IDBTransaction,
694
- func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,
695
- ): void {
696
- let session: InboundGroupSessionData | null | boolean = false;
697
- let withheld: IWithheld | null | boolean = false;
698
- const objectStore = txn.objectStore("inbound_group_sessions");
699
- const getReq = objectStore.get([senderCurve25519Key, sessionId]);
700
- getReq.onsuccess = function (): void {
701
- try {
702
- if (getReq.result) {
703
- session = getReq.result.session;
704
- } else {
705
- session = null;
706
- }
707
- if (withheld !== false) {
708
- func(session as InboundGroupSessionData, withheld as IWithheld);
709
- }
710
- } catch (e) {
711
- abortWithException(txn, <Error>e);
712
- }
713
- };
714
-
715
- const withheldObjectStore = txn.objectStore("inbound_group_sessions_withheld");
716
- const withheldGetReq = withheldObjectStore.get([senderCurve25519Key, sessionId]);
717
- withheldGetReq.onsuccess = function (): void {
718
- try {
719
- if (withheldGetReq.result) {
720
- withheld = withheldGetReq.result.session;
721
- } else {
722
- withheld = null;
723
- }
724
- if (session !== false) {
725
- func(session as InboundGroupSessionData, withheld as IWithheld);
726
- }
727
- } catch (e) {
728
- abortWithException(txn, <Error>e);
729
- }
730
- };
731
- }
732
-
733
- public getAllEndToEndInboundGroupSessions(txn: IDBTransaction, func: (session: ISession | null) => void): void {
734
- const objectStore = txn.objectStore("inbound_group_sessions");
735
- const getReq = objectStore.openCursor();
736
- getReq.onsuccess = function (): void {
737
- const cursor = getReq.result;
738
- if (cursor) {
739
- try {
740
- func({
741
- senderKey: cursor.value.senderCurve25519Key,
742
- sessionId: cursor.value.sessionId,
743
- sessionData: cursor.value.session,
744
- });
745
- } catch (e) {
746
- abortWithException(txn, <Error>e);
747
- }
748
- cursor.continue();
749
- } else {
750
- try {
751
- func(null);
752
- } catch (e) {
753
- abortWithException(txn, <Error>e);
754
- }
755
- }
756
- };
757
- }
758
-
759
- public addEndToEndInboundGroupSession(
760
- senderCurve25519Key: string,
761
- sessionId: string,
762
- sessionData: InboundGroupSessionData,
763
- txn: IDBTransaction,
764
- ): void {
765
- const objectStore = txn.objectStore("inbound_group_sessions");
766
- const addReq = objectStore.add({
767
- senderCurve25519Key,
768
- sessionId,
769
- session: sessionData,
770
- });
771
- addReq.onerror = (ev): void => {
772
- if (addReq.error?.name === "ConstraintError") {
773
- // This stops the error from triggering the txn's onerror
774
- ev.stopPropagation();
775
- // ...and this stops it from aborting the transaction
776
- ev.preventDefault();
777
- logger.log("Ignoring duplicate inbound group session: " + senderCurve25519Key + " / " + sessionId);
778
- } else {
779
- abortWithException(txn, new Error("Failed to add inbound group session: " + addReq.error));
780
- }
781
- };
782
- }
783
-
784
- public storeEndToEndInboundGroupSession(
785
- senderCurve25519Key: string,
786
- sessionId: string,
787
- sessionData: InboundGroupSessionData,
788
- txn: IDBTransaction,
789
- ): void {
790
- const objectStore = txn.objectStore("inbound_group_sessions");
791
- objectStore.put({
792
- senderCurve25519Key,
793
- sessionId,
794
- session: sessionData,
795
- });
796
- }
797
-
798
- public storeEndToEndInboundGroupSessionWithheld(
799
- senderCurve25519Key: string,
800
- sessionId: string,
801
- sessionData: IWithheld,
802
- txn: IDBTransaction,
803
- ): void {
804
- const objectStore = txn.objectStore("inbound_group_sessions_withheld");
805
- objectStore.put({
806
- senderCurve25519Key,
807
- sessionId,
808
- session: sessionData,
809
- });
810
- }
811
-
812
- /**
813
- * Count the number of Megolm sessions in the database.
814
- *
815
- * Implementation of {@link CryptoStore.countEndToEndInboundGroupSessions}.
816
- *
817
- * @internal
818
- */
819
- public async countEndToEndInboundGroupSessions(): Promise<number> {
820
- let result = 0;
821
- await this.doTxn("readonly", [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS], (txn) => {
822
- const sessionStore = txn.objectStore(IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS);
823
- const countReq = sessionStore.count();
824
- countReq.onsuccess = (): void => {
825
- result = countReq.result;
826
- };
827
- });
828
- return result;
829
- }
830
-
831
- /**
832
- * Fetch a batch of Megolm sessions from the database.
833
- *
834
- * Implementation of {@link CryptoStore.getEndToEndInboundGroupSessionsBatch}.
835
- */
836
- public async getEndToEndInboundGroupSessionsBatch(): Promise<null | SessionExtended[]> {
837
- const result: SessionExtended[] = [];
838
- await this.doTxn(
839
- "readonly",
840
- [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS, IndexedDBCryptoStore.STORE_BACKUP],
841
- (txn) => {
842
- const sessionStore = txn.objectStore(IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS);
843
- const backupStore = txn.objectStore(IndexedDBCryptoStore.STORE_BACKUP);
844
-
845
- const getReq = sessionStore.openCursor();
846
- getReq.onsuccess = function (): void {
847
- try {
848
- const cursor = getReq.result;
849
- if (cursor) {
850
- const backupGetReq = backupStore.get(cursor.key);
851
- backupGetReq.onsuccess = (): void => {
852
- result.push({
853
- senderKey: cursor.value.senderCurve25519Key,
854
- sessionId: cursor.value.sessionId,
855
- sessionData: cursor.value.session,
856
- needsBackup: backupGetReq.result !== undefined,
857
- });
858
- if (result.length < SESSION_BATCH_SIZE) {
859
- cursor.continue();
860
- }
861
- };
862
- }
863
- } catch (e) {
864
- abortWithException(txn, <Error>e);
865
- }
866
- };
867
- },
868
- );
869
-
870
- if (result.length === 0) {
871
- // No sessions left.
872
- return null;
873
- }
874
-
875
- return result;
876
- }
877
-
878
- /**
879
- * Delete a batch of Megolm sessions from the database.
880
- *
881
- * Implementation of {@link CryptoStore.deleteEndToEndInboundGroupSessionsBatch}.
882
- *
883
- * @internal
884
- */
885
- public async deleteEndToEndInboundGroupSessionsBatch(
886
- sessions: { senderKey: string; sessionId: string }[],
887
- ): Promise<void> {
888
- await this.doTxn("readwrite", [IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS], async (txn) => {
889
- try {
890
- const objectStore = txn.objectStore(IndexedDBCryptoStore.STORE_INBOUND_GROUP_SESSIONS);
891
- for (const { senderKey, sessionId } of sessions) {
892
- const req = objectStore.delete([senderKey, sessionId]);
893
- await new Promise((resolve) => {
894
- req.onsuccess = resolve;
895
- });
896
- }
897
- } catch (e) {
898
- abortWithException(txn, <Error>e);
899
- }
900
- });
901
- }
902
-
903
- public getEndToEndDeviceData(txn: IDBTransaction, func: (deviceData: IDeviceData | null) => void): void {
904
- const objectStore = txn.objectStore("device_data");
905
- const getReq = objectStore.get("-");
906
- getReq.onsuccess = function (): void {
907
- try {
908
- func(getReq.result || null);
909
- } catch (e) {
910
- abortWithException(txn, <Error>e);
911
- }
912
- };
913
- }
914
-
915
- public storeEndToEndDeviceData(deviceData: IDeviceData, txn: IDBTransaction): void {
916
- const objectStore = txn.objectStore("device_data");
917
- objectStore.put(deviceData, "-");
918
- }
919
-
920
- public storeEndToEndRoom(roomId: string, roomInfo: IRoomEncryption, txn: IDBTransaction): void {
921
- const objectStore = txn.objectStore("rooms");
922
- objectStore.put(roomInfo, roomId);
923
- }
924
-
925
- public getEndToEndRooms(txn: IDBTransaction, func: (rooms: Record<string, IRoomEncryption>) => void): void {
926
- const rooms: Parameters<Parameters<Backend["getEndToEndRooms"]>[1]>[0] = {};
927
- const objectStore = txn.objectStore("rooms");
928
- const getReq = objectStore.openCursor();
929
- getReq.onsuccess = function (): void {
930
- const cursor = getReq.result;
931
- if (cursor) {
932
- rooms[cursor.key as string] = cursor.value;
933
- cursor.continue();
934
- } else {
935
- try {
936
- func(rooms);
937
- } catch (e) {
938
- abortWithException(txn, <Error>e);
939
- }
940
- }
941
- };
942
- }
943
-
944
- // session backups
945
-
946
- public getSessionsNeedingBackup(limit: number): Promise<ISession[]> {
947
- return new Promise((resolve, reject) => {
948
- const sessions: ISession[] = [];
949
-
950
- const txn = this.db.transaction(["sessions_needing_backup", "inbound_group_sessions"], "readonly");
951
- txn.onerror = reject;
952
- txn.oncomplete = function (): void {
953
- resolve(sessions);
954
- };
955
- const objectStore = txn.objectStore("sessions_needing_backup");
956
- const sessionStore = txn.objectStore("inbound_group_sessions");
957
- const getReq = objectStore.openCursor();
958
- getReq.onsuccess = function (): void {
959
- const cursor = getReq.result;
960
- if (cursor) {
961
- const sessionGetReq = sessionStore.get(cursor.key);
962
- sessionGetReq.onsuccess = function (): void {
963
- sessions.push({
964
- senderKey: sessionGetReq.result.senderCurve25519Key,
965
- sessionId: sessionGetReq.result.sessionId,
966
- sessionData: sessionGetReq.result.session,
967
- });
968
- };
969
- if (!limit || sessions.length < limit) {
970
- cursor.continue();
971
- }
972
- }
973
- };
974
- });
975
- }
976
-
977
- public countSessionsNeedingBackup(txn?: IDBTransaction): Promise<number> {
978
- if (!txn) {
979
- txn = this.db.transaction("sessions_needing_backup", "readonly");
980
- }
981
- const objectStore = txn.objectStore("sessions_needing_backup");
982
- return new Promise((resolve, reject) => {
983
- const req = objectStore.count();
984
- req.onerror = reject;
985
- req.onsuccess = (): void => resolve(req.result);
986
- });
987
- }
988
-
989
- public async unmarkSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise<void> {
990
- if (!txn) {
991
- txn = this.db.transaction("sessions_needing_backup", "readwrite");
992
- }
993
- const objectStore = txn.objectStore("sessions_needing_backup");
994
- await Promise.all(
995
- sessions.map((session) => {
996
- return new Promise((resolve, reject) => {
997
- const req = objectStore.delete([session.senderKey, session.sessionId]);
998
- req.onsuccess = resolve;
999
- req.onerror = reject;
1000
- });
1001
- }),
1002
- );
1003
- }
1004
-
1005
- public async markSessionsNeedingBackup(sessions: ISession[], txn?: IDBTransaction): Promise<void> {
1006
- if (!txn) {
1007
- txn = this.db.transaction("sessions_needing_backup", "readwrite");
1008
- }
1009
- const objectStore = txn.objectStore("sessions_needing_backup");
1010
- await Promise.all(
1011
- sessions.map((session) => {
1012
- return new Promise((resolve, reject) => {
1013
- const req = objectStore.put({
1014
- senderCurve25519Key: session.senderKey,
1015
- sessionId: session.sessionId,
1016
- });
1017
- req.onsuccess = resolve;
1018
- req.onerror = reject;
1019
- });
1020
- }),
1021
- );
1022
- }
1023
-
1024
- public addSharedHistoryInboundGroupSession(
1025
- roomId: string,
1026
- senderKey: string,
1027
- sessionId: string,
1028
- txn?: IDBTransaction,
1029
- ): void {
1030
- if (!txn) {
1031
- txn = this.db.transaction("shared_history_inbound_group_sessions", "readwrite");
1032
- }
1033
- const objectStore = txn.objectStore("shared_history_inbound_group_sessions");
1034
- const req = objectStore.get([roomId]);
1035
- req.onsuccess = (): void => {
1036
- const { sessions } = req.result || { sessions: [] };
1037
- sessions.push([senderKey, sessionId]);
1038
- objectStore.put({ roomId, sessions });
1039
- };
1040
- }
1041
-
1042
- public getSharedHistoryInboundGroupSessions(
1043
- roomId: string,
1044
- txn?: IDBTransaction,
1045
- ): Promise<[senderKey: string, sessionId: string][]> {
1046
- if (!txn) {
1047
- txn = this.db.transaction("shared_history_inbound_group_sessions", "readonly");
1048
- }
1049
- const objectStore = txn.objectStore("shared_history_inbound_group_sessions");
1050
- const req = objectStore.get([roomId]);
1051
- return new Promise((resolve, reject) => {
1052
- req.onsuccess = (): void => {
1053
- const { sessions } = req.result || { sessions: [] };
1054
- resolve(sessions);
1055
- };
1056
- req.onerror = reject;
1057
- });
1058
- }
1059
-
1060
- public addParkedSharedHistory(roomId: string, parkedData: ParkedSharedHistory, txn?: IDBTransaction): void {
1061
- if (!txn) {
1062
- txn = this.db.transaction("parked_shared_history", "readwrite");
1063
- }
1064
- const objectStore = txn.objectStore("parked_shared_history");
1065
- const req = objectStore.get([roomId]);
1066
- req.onsuccess = (): void => {
1067
- const { parked } = req.result || { parked: [] };
1068
- parked.push(parkedData);
1069
- objectStore.put({ roomId, parked });
1070
- };
1071
- }
1072
-
1073
- public takeParkedSharedHistory(roomId: string, txn?: IDBTransaction): Promise<ParkedSharedHistory[]> {
1074
- if (!txn) {
1075
- txn = this.db.transaction("parked_shared_history", "readwrite");
1076
- }
1077
- const cursorReq = txn.objectStore("parked_shared_history").openCursor(roomId);
1078
- return new Promise((resolve, reject) => {
1079
- cursorReq.onsuccess = (): void => {
1080
- const cursor = cursorReq.result;
1081
- if (!cursor) {
1082
- resolve([]);
1083
- return;
1084
- }
1085
- const data = cursor.value;
1086
- cursor.delete();
1087
- resolve(data);
1088
- };
1089
- cursorReq.onerror = reject;
1090
- });
1091
- }
1092
-
1093
- public doTxn<T>(
1094
- mode: Mode,
1095
- stores: string | string[],
1096
- func: (txn: IDBTransaction) => T,
1097
- log: Logger = logger,
1098
- ): Promise<T> {
1099
- let startTime: number;
1100
- let description: string;
1101
- if (PROFILE_TRANSACTIONS) {
1102
- const txnId = this.nextTxnId++;
1103
- startTime = Date.now();
1104
- description = `${mode} crypto store transaction ${txnId} in ${stores}`;
1105
- log.debug(`Starting ${description}`);
1106
- }
1107
- const txn = this.db.transaction(stores, mode);
1108
- const promise = promiseifyTxn(txn);
1109
- const result = func(txn);
1110
- if (PROFILE_TRANSACTIONS) {
1111
- promise.then(
1112
- () => {
1113
- const elapsedTime = Date.now() - startTime;
1114
- log.debug(`Finished ${description}, took ${elapsedTime} ms`);
1115
- },
1116
- () => {
1117
- const elapsedTime = Date.now() - startTime;
1118
- log.error(`Failed ${description}, took ${elapsedTime} ms`);
1119
- },
1120
- );
1121
- }
1122
- return promise.then(() => {
1123
- return result;
1124
- });
1125
- }
1126
- }
1127
-
1128
- type DbMigration = (db: IDBDatabase) => void;
1129
- const DB_MIGRATIONS: DbMigration[] = [
1130
- (db): void => {
1131
- createDatabase(db);
1132
- },
1133
- (db): void => {
1134
- db.createObjectStore("account");
1135
- },
1136
- (db): void => {
1137
- const sessionsStore = db.createObjectStore("sessions", {
1138
- keyPath: ["deviceKey", "sessionId"],
1139
- });
1140
- sessionsStore.createIndex("deviceKey", "deviceKey");
1141
- },
1142
- (db): void => {
1143
- db.createObjectStore("inbound_group_sessions", {
1144
- keyPath: ["senderCurve25519Key", "sessionId"],
1145
- });
1146
- },
1147
- (db): void => {
1148
- db.createObjectStore("device_data");
1149
- },
1150
- (db): void => {
1151
- db.createObjectStore("rooms");
1152
- },
1153
- (db): void => {
1154
- db.createObjectStore("sessions_needing_backup", {
1155
- keyPath: ["senderCurve25519Key", "sessionId"],
1156
- });
1157
- },
1158
- (db): void => {
1159
- db.createObjectStore("inbound_group_sessions_withheld", {
1160
- keyPath: ["senderCurve25519Key", "sessionId"],
1161
- });
1162
- },
1163
- (db): void => {
1164
- const problemsStore = db.createObjectStore("session_problems", {
1165
- keyPath: ["deviceKey", "time"],
1166
- });
1167
- problemsStore.createIndex("deviceKey", "deviceKey");
1168
-
1169
- db.createObjectStore("notified_error_devices", {
1170
- keyPath: ["userId", "deviceId"],
1171
- });
1172
- },
1173
- (db): void => {
1174
- db.createObjectStore("shared_history_inbound_group_sessions", {
1175
- keyPath: ["roomId"],
1176
- });
1177
- },
1178
- (db): void => {
1179
- db.createObjectStore("parked_shared_history", {
1180
- keyPath: ["roomId"],
1181
- });
1182
- },
1183
- // Expand as needed.
1184
- ];
1185
- export const VERSION = DB_MIGRATIONS.length;
1186
-
1187
- export function upgradeDatabase(db: IDBDatabase, oldVersion: number): void {
1188
- logger.log(`Upgrading IndexedDBCryptoStore from version ${oldVersion}` + ` to ${VERSION}`);
1189
- DB_MIGRATIONS.forEach((migration, index) => {
1190
- if (oldVersion <= index) migration(db);
1191
- });
1192
- }
1193
-
1194
- function createDatabase(db: IDBDatabase): void {
1195
- const outgoingRoomKeyRequestsStore = db.createObjectStore("outgoingRoomKeyRequests", { keyPath: "requestId" });
1196
-
1197
- // we assume that the RoomKeyRequestBody will have room_id and session_id
1198
- // properties, to make the index efficient.
1199
- outgoingRoomKeyRequestsStore.createIndex("session", ["requestBody.room_id", "requestBody.session_id"]);
1200
-
1201
- outgoingRoomKeyRequestsStore.createIndex("state", "state");
1202
- }
1203
-
1204
- interface IWrappedIDBTransaction extends IDBTransaction {
1205
- _mx_abortexception: Error; // eslint-disable-line camelcase
1206
- }
1207
-
1208
- /*
1209
- * Aborts a transaction with a given exception
1210
- * The transaction promise will be rejected with this exception.
1211
- */
1212
- function abortWithException(txn: IDBTransaction, e: Error): void {
1213
- // We cheekily stick our exception onto the transaction object here
1214
- // We could alternatively make the thing we pass back to the app
1215
- // an object containing the transaction and exception.
1216
- (txn as IWrappedIDBTransaction)._mx_abortexception = e;
1217
- try {
1218
- txn.abort();
1219
- } catch {
1220
- // sometimes we won't be able to abort the transaction
1221
- // (ie. if it's aborted or completed)
1222
- }
1223
- }
1224
-
1225
- function promiseifyTxn<T>(txn: IDBTransaction): Promise<T | null> {
1226
- return new Promise((resolve, reject) => {
1227
- txn.oncomplete = (): void => {
1228
- if ((txn as IWrappedIDBTransaction)._mx_abortexception !== undefined) {
1229
- reject((txn as IWrappedIDBTransaction)._mx_abortexception);
1230
- }
1231
- resolve(null);
1232
- };
1233
- txn.onerror = (event): void => {
1234
- if ((txn as IWrappedIDBTransaction)._mx_abortexception !== undefined) {
1235
- reject((txn as IWrappedIDBTransaction)._mx_abortexception);
1236
- } else {
1237
- logger.log("Error performing indexeddb txn", event);
1238
- reject(txn.error);
1239
- }
1240
- };
1241
- txn.onabort = (event): void => {
1242
- if ((txn as IWrappedIDBTransaction)._mx_abortexception !== undefined) {
1243
- reject((txn as IWrappedIDBTransaction)._mx_abortexception);
1244
- } else {
1245
- logger.log("Error performing indexeddb txn", event);
1246
- reject(txn.error);
1247
- }
1248
- };
1249
- });
1250
- }