@textrp/briij-js-sdk 41.0.1 → 43.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 (380) hide show
  1. package/CHANGELOG.md +14 -1
  2. package/LICENSE +177 -177
  3. package/README.md +85 -3
  4. package/lib/@types/AESEncryptedSecretStoragePayload.js.map +1 -1
  5. package/lib/@types/IIdentityServerProvider.js.map +1 -1
  6. package/lib/@types/PushRules.js +14 -14
  7. package/lib/@types/PushRules.js.map +1 -1
  8. package/lib/@types/another-json.d.js.map +1 -1
  9. package/lib/@types/auth.d.ts +72 -1
  10. package/lib/@types/auth.d.ts.map +1 -1
  11. package/lib/@types/auth.js +57 -54
  12. package/lib/@types/auth.js.map +1 -1
  13. package/lib/@types/beacon.js +100 -100
  14. package/lib/@types/beacon.js.map +1 -1
  15. package/lib/@types/common.js.map +1 -1
  16. package/lib/@types/crypto.js.map +1 -1
  17. package/lib/@types/event.d.ts +59 -0
  18. package/lib/@types/event.d.ts.map +1 -1
  19. package/lib/@types/event.js +105 -102
  20. package/lib/@types/event.js.map +1 -1
  21. package/lib/@types/events.js.map +1 -1
  22. package/lib/@types/extensible_events.js +53 -53
  23. package/lib/@types/extensible_events.js.map +1 -1
  24. package/lib/@types/local_notifications.js.map +1 -1
  25. package/lib/@types/location.js +41 -41
  26. package/lib/@types/location.js.map +1 -1
  27. package/lib/@types/matrix-sdk-crypto-wasm.d.js.map +1 -1
  28. package/lib/@types/media.js.map +1 -1
  29. package/lib/@types/membership.js +39 -39
  30. package/lib/@types/membership.js.map +1 -1
  31. package/lib/@types/partials.js +25 -25
  32. package/lib/@types/partials.js.map +1 -1
  33. package/lib/@types/polls.js +46 -46
  34. package/lib/@types/polls.js.map +1 -1
  35. package/lib/@types/read_receipts.js +14 -14
  36. package/lib/@types/read_receipts.js.map +1 -1
  37. package/lib/@types/registration.js.map +1 -1
  38. package/lib/@types/search.js +14 -14
  39. package/lib/@types/search.js.map +1 -1
  40. package/lib/@types/signed.js.map +1 -1
  41. package/lib/@types/spaces.js.map +1 -1
  42. package/lib/@types/state_events.js.map +1 -1
  43. package/lib/@types/synapse.js.map +1 -1
  44. package/lib/@types/sync.js +18 -18
  45. package/lib/@types/sync.js.map +1 -1
  46. package/lib/@types/threepids.js +14 -14
  47. package/lib/@types/threepids.js.map +1 -1
  48. package/lib/@types/topic.js +47 -47
  49. package/lib/@types/topic.js.map +1 -1
  50. package/lib/@types/uia.js.map +1 -1
  51. package/lib/NamespacedValue.js +20 -20
  52. package/lib/NamespacedValue.js.map +1 -1
  53. package/lib/ReEmitter.js +16 -16
  54. package/lib/ReEmitter.js.map +1 -1
  55. package/lib/base64.js +32 -32
  56. package/lib/base64.js.map +1 -1
  57. package/lib/briij.d.ts +4 -0
  58. package/lib/briij.d.ts.map +1 -1
  59. package/lib/briij.js +4 -0
  60. package/lib/briij.js.map +1 -1
  61. package/lib/client.d.ts +48 -1
  62. package/lib/client.d.ts.map +1 -1
  63. package/lib/client.js +262 -108
  64. package/lib/client.js.map +1 -1
  65. package/lib/common-crypto/key-passphrase.js +19 -19
  66. package/lib/common-crypto/key-passphrase.js.map +1 -1
  67. package/lib/content-helpers.js +57 -57
  68. package/lib/content-helpers.js.map +1 -1
  69. package/lib/content-repo.js +36 -36
  70. package/lib/content-repo.js.map +1 -1
  71. package/lib/crypto/store/base.js +69 -69
  72. package/lib/crypto/store/base.js.map +1 -1
  73. package/lib/crypto/store/indexeddb-crypto-store-backend.js +58 -58
  74. package/lib/crypto/store/indexeddb-crypto-store-backend.js.map +1 -1
  75. package/lib/crypto/store/indexeddb-crypto-store.js +193 -193
  76. package/lib/crypto/store/indexeddb-crypto-store.js.map +1 -1
  77. package/lib/crypto/store/localStorage-crypto-store.js +72 -72
  78. package/lib/crypto/store/localStorage-crypto-store.js.map +1 -1
  79. package/lib/crypto/store/memory-crypto-store.js +74 -74
  80. package/lib/crypto/store/memory-crypto-store.js.map +1 -1
  81. package/lib/crypto-api/CryptoEventHandlerMap.js.map +1 -1
  82. package/lib/crypto-api/key-passphrase.js +22 -22
  83. package/lib/crypto-api/key-passphrase.js.map +1 -1
  84. package/lib/crypto-api/keybackup.js.map +1 -1
  85. package/lib/crypto-api/recovery-key.js +20 -20
  86. package/lib/crypto-api/recovery-key.js.map +1 -1
  87. package/lib/digest.js +21 -21
  88. package/lib/digest.js.map +1 -1
  89. package/lib/extensible_events_v1/ExtensibleEvent.js +39 -39
  90. package/lib/extensible_events_v1/ExtensibleEvent.js.map +1 -1
  91. package/lib/extensible_events_v1/InvalidEventError.js +16 -16
  92. package/lib/extensible_events_v1/InvalidEventError.js.map +1 -1
  93. package/lib/extensible_events_v1/MessageEvent.js +39 -39
  94. package/lib/extensible_events_v1/MessageEvent.js.map +1 -1
  95. package/lib/extensible_events_v1/PollEndEvent.js +29 -29
  96. package/lib/extensible_events_v1/PollEndEvent.js.map +1 -1
  97. package/lib/extensible_events_v1/PollResponseEvent.js +39 -39
  98. package/lib/extensible_events_v1/PollResponseEvent.js.map +1 -1
  99. package/lib/extensible_events_v1/PollStartEvent.js +52 -52
  100. package/lib/extensible_events_v1/PollStartEvent.js.map +1 -1
  101. package/lib/extensible_events_v1/utilities.js +22 -22
  102. package/lib/extensible_events_v1/utilities.js.map +1 -1
  103. package/lib/feature.js +16 -16
  104. package/lib/feature.js.map +1 -1
  105. package/lib/http-api/method.js +14 -14
  106. package/lib/http-api/method.js.map +1 -1
  107. package/lib/http-api/prefix.js +26 -26
  108. package/lib/http-api/prefix.js.map +1 -1
  109. package/lib/indexeddb-helpers.js +21 -21
  110. package/lib/indexeddb-helpers.js.map +1 -1
  111. package/lib/indexeddb-worker.js +18 -18
  112. package/lib/indexeddb-worker.js.map +1 -1
  113. package/lib/matrixrtc/IKeyTransport.js +17 -17
  114. package/lib/matrixrtc/IKeyTransport.js.map +1 -1
  115. package/lib/matrixrtc/IMembershipManager.js +27 -27
  116. package/lib/matrixrtc/IMembershipManager.js.map +1 -1
  117. package/lib/matrixrtc/LivekitTransport.js +19 -19
  118. package/lib/matrixrtc/LivekitTransport.js.map +1 -1
  119. package/lib/matrixrtc/index.js +14 -14
  120. package/lib/matrixrtc/index.js.map +1 -1
  121. package/lib/matrixrtc/utils.js +27 -27
  122. package/lib/matrixrtc/utils.js.map +1 -1
  123. package/lib/models/ToDeviceMessage.js.map +1 -1
  124. package/lib/models/device.js +24 -24
  125. package/lib/models/device.js.map +1 -1
  126. package/lib/models/event-status.js +17 -17
  127. package/lib/models/event-status.js.map +1 -1
  128. package/lib/models/invites-ignorer-types.js +25 -25
  129. package/lib/models/invites-ignorer-types.js.map +1 -1
  130. package/lib/models/profile-keys.js +26 -26
  131. package/lib/models/profile-keys.js.map +1 -1
  132. package/lib/models/room-summary.js +26 -26
  133. package/lib/models/room-summary.js.map +1 -1
  134. package/lib/models/search-result.js +22 -22
  135. package/lib/models/search-result.js.map +1 -1
  136. package/lib/models/typed-event-emitter.js +122 -122
  137. package/lib/models/typed-event-emitter.js.map +1 -1
  138. package/lib/oidc/authorize.js +76 -76
  139. package/lib/oidc/authorize.js.map +1 -1
  140. package/lib/oidc/error.js +17 -17
  141. package/lib/oidc/error.js.map +1 -1
  142. package/lib/oidc/index.js +17 -17
  143. package/lib/oidc/index.js.map +1 -1
  144. package/lib/oidc/register.js +41 -41
  145. package/lib/oidc/register.js.map +1 -1
  146. package/lib/oidc/tokenRefresher.js +51 -51
  147. package/lib/oidc/tokenRefresher.js.map +1 -1
  148. package/lib/oidc/validate.js +59 -59
  149. package/lib/oidc/validate.js.map +1 -1
  150. package/lib/randomstring.js +35 -35
  151. package/lib/randomstring.js.map +1 -1
  152. package/lib/realtime-callbacks.js +39 -39
  153. package/lib/realtime-callbacks.js.map +1 -1
  154. package/lib/receipt-accumulator.js +44 -44
  155. package/lib/receipt-accumulator.js.map +1 -1
  156. package/lib/rendezvous/RendezvousChannel.js.map +1 -1
  157. package/lib/rendezvous/RendezvousCode.js.map +1 -1
  158. package/lib/rendezvous/RendezvousError.js +14 -14
  159. package/lib/rendezvous/RendezvousError.js.map +1 -1
  160. package/lib/rendezvous/RendezvousFailureReason.js +14 -14
  161. package/lib/rendezvous/RendezvousFailureReason.js.map +1 -1
  162. package/lib/rendezvous/RendezvousIntent.js +14 -14
  163. package/lib/rendezvous/RendezvousIntent.js.map +1 -1
  164. package/lib/rendezvous/RendezvousTransport.js.map +1 -1
  165. package/lib/rendezvous/channels/MSC4108SecureChannel.js +63 -63
  166. package/lib/rendezvous/channels/MSC4108SecureChannel.js.map +1 -1
  167. package/lib/rendezvous/channels/index.js +14 -14
  168. package/lib/rendezvous/channels/index.js.map +1 -1
  169. package/lib/rendezvous/index.js +14 -14
  170. package/lib/rendezvous/index.js.map +1 -1
  171. package/lib/rendezvous/transports/index.js +14 -14
  172. package/lib/rendezvous/transports/index.js.map +1 -1
  173. package/lib/rust-crypto/CrossSigningIdentity.js +29 -29
  174. package/lib/rust-crypto/CrossSigningIdentity.js.map +1 -1
  175. package/lib/rust-crypto/OutgoingRequestsManager.js +37 -37
  176. package/lib/rust-crypto/OutgoingRequestsManager.js.map +1 -1
  177. package/lib/rust-crypto/device-converter.js +30 -30
  178. package/lib/rust-crypto/device-converter.js.map +1 -1
  179. package/lib/rust-crypto/secret-storage.js +30 -30
  180. package/lib/rust-crypto/secret-storage.js.map +1 -1
  181. package/lib/service-types.js +14 -14
  182. package/lib/service-types.js.map +1 -1
  183. package/lib/store/local-storage-events-emitter.js +21 -21
  184. package/lib/store/local-storage-events-emitter.js.map +1 -1
  185. package/lib/sync-accumulator.js +50 -50
  186. package/lib/sync-accumulator.js.map +1 -1
  187. package/lib/thread-utils.js +20 -20
  188. package/lib/thread-utils.js.map +1 -1
  189. package/lib/types.js +34 -34
  190. package/lib/types.js.map +1 -1
  191. package/lib/utils/decryptAESSecretStorageItem.js +22 -22
  192. package/lib/utils/decryptAESSecretStorageItem.js.map +1 -1
  193. package/lib/utils/encryptAESSecretStorageItem.js +26 -26
  194. package/lib/utils/encryptAESSecretStorageItem.js.map +1 -1
  195. package/lib/utils/internal/deriveKeys.js +21 -21
  196. package/lib/utils/internal/deriveKeys.js.map +1 -1
  197. package/lib/utils/roomVersion.js +26 -26
  198. package/lib/utils/roomVersion.js.map +1 -1
  199. package/lib/version-support.js +26 -26
  200. package/lib/version-support.js.map +1 -1
  201. package/lib/wallet-recovery.d.ts +24 -0
  202. package/lib/wallet-recovery.d.ts.map +1 -0
  203. package/lib/wallet-recovery.js +232 -0
  204. package/lib/wallet-recovery.js.map +1 -0
  205. package/lib/webrtc/audioContext.js +24 -24
  206. package/lib/webrtc/audioContext.js.map +1 -1
  207. package/lib/webrtc/callEventTypes.js.map +1 -1
  208. package/lib/webrtc/stats/callFeedStatsReporter.js +14 -14
  209. package/lib/webrtc/stats/callFeedStatsReporter.js.map +1 -1
  210. package/lib/webrtc/stats/callStatsReportGatherer.js +14 -14
  211. package/lib/webrtc/stats/callStatsReportGatherer.js.map +1 -1
  212. package/lib/webrtc/stats/callStatsReportSummary.js.map +1 -1
  213. package/lib/webrtc/stats/connectionStats.js +14 -14
  214. package/lib/webrtc/stats/connectionStats.js.map +1 -1
  215. package/lib/webrtc/stats/connectionStatsBuilder.js +14 -14
  216. package/lib/webrtc/stats/connectionStatsBuilder.js.map +1 -1
  217. package/lib/webrtc/stats/connectionStatsReportBuilder.js +14 -14
  218. package/lib/webrtc/stats/connectionStatsReportBuilder.js.map +1 -1
  219. package/lib/webrtc/stats/groupCallStats.js +14 -14
  220. package/lib/webrtc/stats/groupCallStats.js.map +1 -1
  221. package/lib/webrtc/stats/media/mediaSsrcHandler.js +14 -14
  222. package/lib/webrtc/stats/media/mediaSsrcHandler.js.map +1 -1
  223. package/lib/webrtc/stats/media/mediaTrackHandler.js +14 -14
  224. package/lib/webrtc/stats/media/mediaTrackHandler.js.map +1 -1
  225. package/lib/webrtc/stats/media/mediaTrackStats.js +27 -27
  226. package/lib/webrtc/stats/media/mediaTrackStats.js.map +1 -1
  227. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js +20 -20
  228. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map +1 -1
  229. package/lib/webrtc/stats/statsReport.js +14 -14
  230. package/lib/webrtc/stats/statsReport.js.map +1 -1
  231. package/lib/webrtc/stats/statsReportEmitter.js +14 -14
  232. package/lib/webrtc/stats/statsReportEmitter.js.map +1 -1
  233. package/lib/webrtc/stats/trackStatsBuilder.js +4 -4
  234. package/lib/webrtc/stats/trackStatsBuilder.js.map +1 -1
  235. package/lib/webrtc/stats/transportStats.js.map +1 -1
  236. package/lib/webrtc/stats/transportStatsBuilder.js.map +1 -1
  237. package/lib/webrtc/stats/valueFormatter.js +11 -11
  238. package/lib/webrtc/stats/valueFormatter.js.map +1 -1
  239. package/lib/xrpl/identity.d.ts +28 -0
  240. package/lib/xrpl/identity.d.ts.map +1 -0
  241. package/lib/xrpl/identity.js +213 -0
  242. package/lib/xrpl/identity.js.map +1 -0
  243. package/lib/xrpl/trust.d.ts +8 -0
  244. package/lib/xrpl/trust.d.ts.map +1 -0
  245. package/lib/xrpl/trust.js +61 -0
  246. package/lib/xrpl/trust.js.map +1 -0
  247. package/lib/xrpl/verification.d.ts +26 -0
  248. package/lib/xrpl/verification.d.ts.map +1 -0
  249. package/lib/xrpl/verification.js +295 -0
  250. package/lib/xrpl/verification.js.map +1 -0
  251. package/package.json +130 -129
  252. package/src/@types/AESEncryptedSecretStoragePayload.ts +29 -29
  253. package/src/@types/IIdentityServerProvider.ts +24 -24
  254. package/src/@types/PushRules.ts +208 -208
  255. package/src/@types/another-json.d.ts +19 -19
  256. package/src/@types/auth.ts +340 -258
  257. package/src/@types/beacon.ts +140 -140
  258. package/src/@types/common.ts +24 -24
  259. package/src/@types/crypto.ts +71 -71
  260. package/src/@types/event.ts +508 -449
  261. package/src/@types/events.ts +119 -119
  262. package/src/@types/extensible_events.ts +147 -147
  263. package/src/@types/local_notifications.ts +19 -19
  264. package/src/@types/location.ts +92 -92
  265. package/src/@types/matrix-sdk-crypto-wasm.d.ts +39 -39
  266. package/src/@types/media.ts +245 -245
  267. package/src/@types/membership.ts +57 -57
  268. package/src/@types/partials.ts +103 -103
  269. package/src/@types/polls.ts +120 -120
  270. package/src/@types/read_receipts.ts +61 -61
  271. package/src/@types/registration.ts +102 -102
  272. package/src/@types/search.ts +119 -119
  273. package/src/@types/signed.ts +25 -25
  274. package/src/@types/spaces.ts +37 -37
  275. package/src/@types/state_events.ts +153 -153
  276. package/src/@types/synapse.ts +40 -40
  277. package/src/@types/sync.ts +27 -27
  278. package/src/@types/threepids.ts +29 -29
  279. package/src/@types/topic.ts +69 -69
  280. package/src/@types/uia.ts +24 -24
  281. package/src/NamespacedValue.ts +121 -121
  282. package/src/ReEmitter.ts +93 -93
  283. package/src/base64.ts +86 -86
  284. package/src/briij.ts +4 -0
  285. package/src/client.ts +183 -10
  286. package/src/common-crypto/README.md +4 -4
  287. package/src/common-crypto/key-passphrase.ts +43 -43
  288. package/src/content-helpers.ts +298 -298
  289. package/src/content-repo.ts +122 -122
  290. package/src/crypto/store/base.ts +388 -388
  291. package/src/crypto/store/indexeddb-crypto-store-backend.ts +655 -655
  292. package/src/crypto/store/indexeddb-crypto-store.ts +555 -555
  293. package/src/crypto/store/localStorage-crypto-store.ts +409 -409
  294. package/src/crypto/store/memory-crypto-store.ts +326 -326
  295. package/src/crypto-api/CryptoEventHandlerMap.ts +42 -42
  296. package/src/crypto-api/key-passphrase.ts +58 -58
  297. package/src/crypto-api/keybackup.ts +114 -114
  298. package/src/crypto-api/recovery-key.ts +69 -69
  299. package/src/digest.ts +34 -34
  300. package/src/extensible_events_v1/ExtensibleEvent.ts +58 -58
  301. package/src/extensible_events_v1/InvalidEventError.ts +24 -24
  302. package/src/extensible_events_v1/MessageEvent.ts +143 -143
  303. package/src/extensible_events_v1/PollEndEvent.ts +97 -97
  304. package/src/extensible_events_v1/PollResponseEvent.ts +148 -148
  305. package/src/extensible_events_v1/PollStartEvent.ts +207 -207
  306. package/src/extensible_events_v1/utilities.ts +35 -35
  307. package/src/feature.ts +88 -88
  308. package/src/http-api/method.ts +25 -25
  309. package/src/http-api/prefix.ts +48 -48
  310. package/src/indexeddb-helpers.ts +50 -50
  311. package/src/indexeddb-worker.ts +24 -24
  312. package/src/matrixrtc/IKeyTransport.ts +63 -63
  313. package/src/matrixrtc/IMembershipManager.ts +120 -120
  314. package/src/matrixrtc/LivekitTransport.ts +46 -46
  315. package/src/matrixrtc/index.ts +24 -24
  316. package/src/matrixrtc/utils.ts +71 -71
  317. package/src/models/ToDeviceMessage.ts +38 -38
  318. package/src/models/device.ts +85 -85
  319. package/src/models/event-status.ts +39 -39
  320. package/src/models/invites-ignorer-types.ts +58 -58
  321. package/src/models/profile-keys.ts +33 -33
  322. package/src/models/room-summary.ts +78 -78
  323. package/src/models/search-result.ts +57 -57
  324. package/src/models/typed-event-emitter.ts +246 -246
  325. package/src/oidc/authorize.ts +279 -279
  326. package/src/oidc/error.ts +33 -33
  327. package/src/oidc/index.ts +33 -33
  328. package/src/oidc/register.ts +163 -163
  329. package/src/oidc/tokenRefresher.ts +184 -184
  330. package/src/oidc/validate.ts +265 -265
  331. package/src/randomstring.ts +103 -103
  332. package/src/realtime-callbacks.ts +191 -191
  333. package/src/receipt-accumulator.ts +189 -189
  334. package/src/rendezvous/RendezvousChannel.ts +48 -48
  335. package/src/rendezvous/RendezvousCode.ts +25 -25
  336. package/src/rendezvous/RendezvousError.ts +26 -26
  337. package/src/rendezvous/RendezvousFailureReason.ts +49 -49
  338. package/src/rendezvous/RendezvousIntent.ts +20 -20
  339. package/src/rendezvous/RendezvousTransport.ts +58 -58
  340. package/src/rendezvous/channels/MSC4108SecureChannel.ts +270 -270
  341. package/src/rendezvous/channels/index.ts +17 -17
  342. package/src/rendezvous/index.ts +25 -25
  343. package/src/rendezvous/transports/index.ts +17 -17
  344. package/src/rust-crypto/CrossSigningIdentity.ts +195 -195
  345. package/src/rust-crypto/OutgoingRequestsManager.ts +170 -170
  346. package/src/rust-crypto/device-converter.ts +128 -128
  347. package/src/rust-crypto/secret-storage.ts +60 -60
  348. package/src/service-types.ts +20 -20
  349. package/src/store/local-storage-events-emitter.ts +46 -46
  350. package/src/sync-accumulator.ts +779 -779
  351. package/src/thread-utils.ts +31 -31
  352. package/src/types.ts +59 -59
  353. package/src/utils/decryptAESSecretStorageItem.ts +54 -54
  354. package/src/utils/encryptAESSecretStorageItem.ts +73 -73
  355. package/src/utils/internal/deriveKeys.ts +63 -63
  356. package/src/utils/roomVersion.ts +35 -35
  357. package/src/version-support.ts +50 -50
  358. package/src/wallet-recovery.ts +252 -0
  359. package/src/webrtc/audioContext.ts +44 -44
  360. package/src/webrtc/callEventTypes.ts +101 -101
  361. package/src/webrtc/stats/callFeedStatsReporter.ts +91 -91
  362. package/src/webrtc/stats/callStatsReportGatherer.ts +219 -219
  363. package/src/webrtc/stats/callStatsReportSummary.ts +30 -30
  364. package/src/webrtc/stats/connectionStats.ts +47 -47
  365. package/src/webrtc/stats/connectionStatsBuilder.ts +28 -28
  366. package/src/webrtc/stats/connectionStatsReportBuilder.ts +140 -140
  367. package/src/webrtc/stats/groupCallStats.ts +93 -93
  368. package/src/webrtc/stats/media/mediaSsrcHandler.ts +57 -57
  369. package/src/webrtc/stats/media/mediaTrackHandler.ts +70 -70
  370. package/src/webrtc/stats/media/mediaTrackStats.ts +176 -176
  371. package/src/webrtc/stats/media/mediaTrackStatsHandler.ts +90 -90
  372. package/src/webrtc/stats/statsReport.ts +133 -133
  373. package/src/webrtc/stats/statsReportEmitter.ts +49 -49
  374. package/src/webrtc/stats/trackStatsBuilder.ts +207 -207
  375. package/src/webrtc/stats/transportStats.ts +26 -26
  376. package/src/webrtc/stats/transportStatsBuilder.ts +48 -48
  377. package/src/webrtc/stats/valueFormatter.ts +27 -27
  378. package/src/xrpl/identity.ts +245 -0
  379. package/src/xrpl/trust.ts +64 -0
  380. package/src/xrpl/verification.ts +284 -0
@@ -1,25 +1,25 @@
1
- /*
2
- Copyright 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.
1
+ /*
2
+ Copyright 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
15
  */
16
16
 
17
- /**
18
- * Internal module. Definitions for storage for the crypto module
17
+ /**
18
+ * Internal module. Definitions for storage for the crypto module
19
19
  */
20
20
 
21
- /**
22
- * Abstraction of things that can store data required for end-to-end encryption
21
+ /**
22
+ * Abstraction of things that can store data required for end-to-end encryption
23
23
  */
24
24
 
25
25
  /** Data on a Megolm session */
@@ -28,23 +28,23 @@ limitations under the License.
28
28
 
29
29
  /** Data on an Olm session */
30
30
 
31
- /**
32
- * Represents an outgoing room key request
31
+ /**
32
+ * Represents an outgoing room key request
33
33
  */
34
34
 
35
- /**
36
- * Keys for the `account` object store to store the migration state.
37
- * Values are defined in `MigrationState`.
38
- * @internal
35
+ /**
36
+ * Keys for the `account` object store to store the migration state.
37
+ * Values are defined in `MigrationState`.
38
+ * @internal
39
39
  */
40
40
  export var ACCOUNT_OBJECT_KEY_MIGRATION_STATE = "migrationState";
41
41
 
42
- /**
43
- * A record of which steps have been completed in the libolm to Rust Crypto migration.
44
- *
45
- * Used by {@link CryptoStore#getMigrationState} and {@link CryptoStore#setMigrationState}.
46
- *
47
- * @internal
42
+ /**
43
+ * A record of which steps have been completed in the libolm to Rust Crypto migration.
44
+ *
45
+ * Used by {@link CryptoStore#getMigrationState} and {@link CryptoStore#setMigrationState}.
46
+ *
47
+ * @internal
48
48
  */
49
49
  export var MigrationState = /*#__PURE__*/function (MigrationState) {
50
50
  /** No migration steps have yet been completed. */
@@ -57,15 +57,15 @@ export var MigrationState = /*#__PURE__*/function (MigrationState) {
57
57
  MigrationState[MigrationState["MEGOLM_SESSIONS_MIGRATED"] = 3] = "MEGOLM_SESSIONS_MIGRATED";
58
58
  /** MEGOLM_SESSIONS_MIGRATED, and in addition, we have migrated all the room settings. */
59
59
  MigrationState[MigrationState["ROOM_SETTINGS_MIGRATED"] = 4] = "ROOM_SETTINGS_MIGRATED";
60
- /** ROOM_SETTINGS_MIGRATED, and in addition, we have done the first own keys query in order to
60
+ /** ROOM_SETTINGS_MIGRATED, and in addition, we have done the first own keys query in order to
61
61
  * load the public part of the keys that have been migrated */
62
62
  MigrationState[MigrationState["INITIAL_OWN_KEY_QUERY_DONE"] = 5] = "INITIAL_OWN_KEY_QUERY_DONE";
63
63
  return MigrationState;
64
64
  }({});
65
65
 
66
- /**
67
- * The size of batches to be returned by {@link CryptoStore#getEndToEndSessionsBatch} and
68
- * {@link CryptoStore#getEndToEndInboundGroupSessionsBatch}.
66
+ /**
67
+ * The size of batches to be returned by {@link CryptoStore#getEndToEndSessionsBatch} and
68
+ * {@link CryptoStore#getEndToEndInboundGroupSessionsBatch}.
69
69
  */
70
70
  export var SESSION_BATCH_SIZE = 50;
71
71
 
@@ -81,34 +81,34 @@ export var TrackingStatus = /*#__PURE__*/function (TrackingStatus) {
81
81
  return TrackingStatus;
82
82
  }({});
83
83
 
84
- /**
85
- * possible states for a room key request
86
- *
87
- * The state machine looks like:
88
- * ```
89
- *
90
- * | (cancellation sent)
91
- * | .-------------------------------------------------.
92
- * | | |
93
- * V V (cancellation requested) |
94
- * UNSENT -----------------------------+ |
95
- * | | |
96
- * | | |
97
- * | (send successful) | CANCELLATION_PENDING_AND_WILL_RESEND
98
- * V | Λ
99
- * SENT | |
100
- * |-------------------------------- | --------------'
101
- * | | (cancellation requested with intent
102
- * | | to resend the original request)
103
- * | |
104
- * | (cancellation requested) |
105
- * V |
106
- * CANCELLATION_PENDING |
107
- * | |
108
- * | (cancellation sent) |
109
- * V |
110
- * (deleted) <---------------------------+
111
- * ```
84
+ /**
85
+ * possible states for a room key request
86
+ *
87
+ * The state machine looks like:
88
+ * ```
89
+ *
90
+ * | (cancellation sent)
91
+ * | .-------------------------------------------------.
92
+ * | | |
93
+ * V V (cancellation requested) |
94
+ * UNSENT -----------------------------+ |
95
+ * | | |
96
+ * | | |
97
+ * | (send successful) | CANCELLATION_PENDING_AND_WILL_RESEND
98
+ * V | Λ
99
+ * SENT | |
100
+ * |-------------------------------- | --------------'
101
+ * | | (cancellation requested with intent
102
+ * | | to resend the original request)
103
+ * | |
104
+ * | (cancellation requested) |
105
+ * V |
106
+ * CANCELLATION_PENDING |
107
+ * | |
108
+ * | (cancellation sent) |
109
+ * V |
110
+ * (deleted) <---------------------------+
111
+ * ```
112
112
  */
113
113
  export var RoomKeyRequestState = /*#__PURE__*/function (RoomKeyRequestState) {
114
114
  /** request not yet sent */
@@ -117,9 +117,9 @@ export var RoomKeyRequestState = /*#__PURE__*/function (RoomKeyRequestState) {
117
117
  RoomKeyRequestState[RoomKeyRequestState["Sent"] = 1] = "Sent";
118
118
  /** reply received, cancellation not yet sent */
119
119
  RoomKeyRequestState[RoomKeyRequestState["CancellationPending"] = 2] = "CancellationPending";
120
- /**
121
- * Cancellation not yet sent and will transition to UNSENT instead of
122
- * being deleted once the cancellation has been sent.
120
+ /**
121
+ * Cancellation not yet sent and will transition to UNSENT instead of
122
+ * being deleted once the cancellation has been sent.
123
123
  */
124
124
  RoomKeyRequestState[RoomKeyRequestState["CancellationPendingAndWillResend"] = 3] = "CancellationPendingAndWillResend";
125
125
  return RoomKeyRequestState;
@@ -127,10 +127,10 @@ export var RoomKeyRequestState = /*#__PURE__*/function (RoomKeyRequestState) {
127
127
 
128
128
  /* eslint-disable camelcase */
129
129
 
130
- /**
131
- * The parameters of a room key request. The details of the request may
132
- * vary with the crypto algorithm, but the management and storage layers for
133
- * outgoing requests expect it to have 'room_id' and 'session_id' properties.
130
+ /**
131
+ * The parameters of a room key request. The details of the request may
132
+ * vary with the crypto algorithm, but the management and storage layers for
133
+ * outgoing requests expect it to have 'room_id' and 'session_id' properties.
134
134
  */
135
135
 
136
136
  /* eslint-enable camelcase */
@@ -1 +1 @@
1
- {"version":3,"file":"base.js","names":["ACCOUNT_OBJECT_KEY_MIGRATION_STATE","MigrationState","SESSION_BATCH_SIZE","TrackingStatus","RoomKeyRequestState","DeviceVerification"],"sources":["../../../src/crypto/store/base.ts"],"sourcesContent":["/*\r\nCopyright 2021 The Matrix.org Foundation C.I.C.\r\n\r\nLicensed under the Apache License, Version 2.0 (the \"License\");\r\nyou may not use this file except in compliance with the License.\r\nYou may obtain a copy of the License at\r\n\r\n http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nUnless required by applicable law or agreed to in writing, software\r\ndistributed under the License is distributed on an \"AS IS\" BASIS,\r\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\nSee the License for the specific language governing permissions and\r\nlimitations under the License.\r\n*/\r\n\r\nimport { type Logger } from \"../../logger.ts\";\r\nimport { type CrossSigningKeyInfo } from \"../../crypto-api/index.ts\";\r\nimport { type AESEncryptedSecretStoragePayload } from \"../../@types/AESEncryptedSecretStoragePayload.ts\";\r\nimport { type ISignatures } from \"../../@types/signed.ts\";\r\n\r\n/**\r\n * Internal module. Definitions for storage for the crypto module\r\n */\r\n\r\nexport interface SecretStorePrivateKeys {\r\n \"m.megolm_backup.v1\": AESEncryptedSecretStoragePayload;\r\n}\r\n\r\n/**\r\n * Abstraction of things that can store data required for end-to-end encryption\r\n */\r\nexport interface CryptoStore {\r\n /**\r\n * Returns true if this CryptoStore has ever been initialised (ie, it might contain data).\r\n *\r\n * Unlike the rest of the methods in this interface, can be called before {@link CryptoStore#startup}.\r\n *\r\n * @internal\r\n */\r\n containsData(): Promise<boolean>;\r\n\r\n /**\r\n * Initialise this crypto store.\r\n *\r\n * Typically, this involves provisioning storage, and migrating any existing data to the current version of the\r\n * storage schema where appropriate.\r\n *\r\n * Must be called before any of the rest of the methods in this interface.\r\n */\r\n startup(): Promise<CryptoStore>;\r\n\r\n deleteAllData(): Promise<void>;\r\n\r\n /**\r\n * Get data on how much of the libolm to Rust Crypto migration has been done.\r\n *\r\n * @internal\r\n */\r\n getMigrationState(): Promise<MigrationState>;\r\n\r\n /**\r\n * Set data on how much of the libolm to Rust Crypto migration has been done.\r\n *\r\n * @internal\r\n */\r\n setMigrationState(migrationState: MigrationState): Promise<void>;\r\n\r\n // Olm Account\r\n getAccount(txn: unknown, func: (accountPickle: string | null) => void): void;\r\n storeAccount(txn: unknown, accountPickle: string): void;\r\n getCrossSigningKeys(txn: unknown, func: (keys: Record<string, CrossSigningKeyInfo> | null) => void): void;\r\n getSecretStorePrivateKey<K extends keyof SecretStorePrivateKeys>(\r\n txn: unknown,\r\n func: (key: SecretStorePrivateKeys[K] | null) => void,\r\n type: K,\r\n ): void;\r\n storeSecretStorePrivateKey<K extends keyof SecretStorePrivateKeys>(\r\n txn: unknown,\r\n type: K,\r\n key: SecretStorePrivateKeys[K],\r\n ): void;\r\n\r\n // Olm Sessions\r\n countEndToEndSessions(txn: unknown, func: (count: number) => void): void;\r\n getEndToEndSession(\r\n deviceKey: string,\r\n sessionId: string,\r\n txn: unknown,\r\n func: (session: ISessionInfo | null) => void,\r\n ): void;\r\n getEndToEndSessions(\r\n deviceKey: string,\r\n txn: unknown,\r\n func: (sessions: { [sessionId: string]: ISessionInfo }) => void,\r\n ): void;\r\n\r\n storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void;\r\n\r\n /**\r\n * Get a batch of end-to-end sessions from the database.\r\n *\r\n * @returns A batch of Olm Sessions, or `null` if no sessions are left.\r\n * @internal\r\n */\r\n getEndToEndSessionsBatch(): Promise<ISessionInfo[] | null>;\r\n\r\n /**\r\n * Delete a batch of end-to-end sessions from the database.\r\n *\r\n * Any sessions in the list which are not found are silently ignored.\r\n *\r\n * @internal\r\n */\r\n deleteEndToEndSessionsBatch(sessions: { deviceKey?: string; sessionId?: string }[]): Promise<void>;\r\n\r\n // Inbound Group Sessions\r\n getEndToEndInboundGroupSession(\r\n senderCurve25519Key: string,\r\n sessionId: string,\r\n txn: unknown,\r\n func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,\r\n ): void;\r\n storeEndToEndInboundGroupSession(\r\n senderCurve25519Key: string,\r\n sessionId: string,\r\n sessionData: InboundGroupSessionData,\r\n txn: unknown,\r\n ): void;\r\n\r\n /**\r\n * Count the number of Megolm sessions in the database.\r\n *\r\n * @internal\r\n */\r\n countEndToEndInboundGroupSessions(): Promise<number>;\r\n\r\n /**\r\n * Get a batch of Megolm sessions from the database.\r\n *\r\n * @returns A batch of Megolm Sessions, or `null` if no sessions are left.\r\n * @internal\r\n */\r\n getEndToEndInboundGroupSessionsBatch(): Promise<SessionExtended[] | null>;\r\n\r\n /**\r\n * Delete a batch of Megolm sessions from the database.\r\n *\r\n * Any sessions in the list which are not found are silently ignored.\r\n *\r\n * @internal\r\n */\r\n deleteEndToEndInboundGroupSessionsBatch(sessions: { senderKey: string; sessionId: string }[]): Promise<void>;\r\n\r\n // Device Data\r\n getEndToEndRooms(txn: unknown, func: (rooms: Record<string, IRoomEncryption>) => void): void;\r\n markSessionsNeedingBackup(sessions: ISession[], txn?: unknown): Promise<void>;\r\n\r\n // Session key backups\r\n doTxn<T>(mode: Mode, stores: Iterable<string>, func: (txn: unknown) => T, log?: Logger): Promise<T>;\r\n}\r\n\r\nexport type Mode = \"readonly\" | \"readwrite\";\r\n\r\n/** Data on a Megolm session */\r\nexport interface ISession {\r\n senderKey: string;\r\n sessionId: string;\r\n sessionData?: InboundGroupSessionData;\r\n}\r\n\r\n/** Extended data on a Megolm session */\r\nexport interface SessionExtended extends ISession {\r\n needsBackup: boolean;\r\n}\r\n\r\n/** Data on an Olm session */\r\nexport interface ISessionInfo {\r\n deviceKey?: string;\r\n sessionId?: string;\r\n session?: string;\r\n lastReceivedMessageTs?: number;\r\n}\r\n\r\nexport interface IDeviceData {\r\n devices: {\r\n [userId: string]: {\r\n [deviceId: string]: IDevice;\r\n };\r\n };\r\n trackingStatus: {\r\n [userId: string]: TrackingStatus;\r\n };\r\n crossSigningInfo?: Record<string, ICrossSigningInfo>;\r\n syncToken?: string;\r\n}\r\n\r\nexport interface IWithheld {\r\n // eslint-disable-next-line camelcase\r\n room_id: string;\r\n code: string;\r\n reason: string;\r\n}\r\n\r\n/**\r\n * Represents an outgoing room key request\r\n */\r\nexport interface OutgoingRoomKeyRequest {\r\n /**\r\n * Unique id for this request. Used for both an id within the request for later pairing with a cancellation,\r\n * and for the transaction id when sending the to_device messages to our local server.\r\n */\r\n requestId: string;\r\n requestTxnId?: string;\r\n /**\r\n * Transaction id for the cancellation, if any\r\n */\r\n cancellationTxnId?: string;\r\n /**\r\n * List of recipients for the request\r\n */\r\n recipients: IRoomKeyRequestRecipient[];\r\n /**\r\n * Parameters for the request\r\n */\r\n requestBody: IRoomKeyRequestBody;\r\n /**\r\n * current state of this request\r\n */\r\n state: RoomKeyRequestState;\r\n}\r\n\r\n/**\r\n * Keys for the `account` object store to store the migration state.\r\n * Values are defined in `MigrationState`.\r\n * @internal\r\n */\r\nexport const ACCOUNT_OBJECT_KEY_MIGRATION_STATE = \"migrationState\";\r\n\r\n/**\r\n * A record of which steps have been completed in the libolm to Rust Crypto migration.\r\n *\r\n * Used by {@link CryptoStore#getMigrationState} and {@link CryptoStore#setMigrationState}.\r\n *\r\n * @internal\r\n */\r\nexport enum MigrationState {\r\n /** No migration steps have yet been completed. */\r\n NOT_STARTED,\r\n\r\n /** We have migrated the account data, cross-signing keys, etc. */\r\n INITIAL_DATA_MIGRATED,\r\n\r\n /** INITIAL_DATA_MIGRATED, and in addition, we have migrated all the Olm sessions. */\r\n OLM_SESSIONS_MIGRATED,\r\n\r\n /** OLM_SESSIONS_MIGRATED, and in addition, we have migrated all the Megolm sessions. */\r\n MEGOLM_SESSIONS_MIGRATED,\r\n\r\n /** MEGOLM_SESSIONS_MIGRATED, and in addition, we have migrated all the room settings. */\r\n ROOM_SETTINGS_MIGRATED,\r\n\r\n /** ROOM_SETTINGS_MIGRATED, and in addition, we have done the first own keys query in order to\r\n * load the public part of the keys that have been migrated */\r\n INITIAL_OWN_KEY_QUERY_DONE,\r\n}\r\n\r\n/**\r\n * The size of batches to be returned by {@link CryptoStore#getEndToEndSessionsBatch} and\r\n * {@link CryptoStore#getEndToEndInboundGroupSessionsBatch}.\r\n */\r\nexport const SESSION_BATCH_SIZE = 50;\r\n\r\nexport interface InboundGroupSessionData {\r\n room_id: string; // eslint-disable-line camelcase\r\n /** pickled Olm.InboundGroupSession */\r\n session: string;\r\n keysClaimed?: Record<string, string>;\r\n /** Devices involved in forwarding this session to us (normally empty). */\r\n forwardingCurve25519KeyChain: string[];\r\n /** whether this session is untrusted. */\r\n untrusted?: boolean;\r\n /** whether this session exists during the room being set to shared history. */\r\n sharedHistory?: boolean;\r\n}\r\n\r\nexport interface ICrossSigningInfo {\r\n keys: Record<string, CrossSigningKeyInfo>;\r\n firstUse: boolean;\r\n crossSigningVerifiedBefore: boolean;\r\n}\r\n\r\n/* eslint-disable camelcase */\r\nexport interface IRoomEncryption {\r\n algorithm: string;\r\n rotation_period_ms?: number;\r\n rotation_period_msgs?: number;\r\n}\r\n/* eslint-enable camelcase */\r\n\r\nexport enum TrackingStatus {\r\n NotTracked,\r\n PendingDownload,\r\n DownloadInProgress,\r\n UpToDate,\r\n}\r\n\r\n/**\r\n * possible states for a room key request\r\n *\r\n * The state machine looks like:\r\n * ```\r\n *\r\n * | (cancellation sent)\r\n * | .-------------------------------------------------.\r\n * | | |\r\n * V V (cancellation requested) |\r\n * UNSENT -----------------------------+ |\r\n * | | |\r\n * | | |\r\n * | (send successful) | CANCELLATION_PENDING_AND_WILL_RESEND\r\n * V | Λ\r\n * SENT | |\r\n * |-------------------------------- | --------------'\r\n * | | (cancellation requested with intent\r\n * | | to resend the original request)\r\n * | |\r\n * | (cancellation requested) |\r\n * V |\r\n * CANCELLATION_PENDING |\r\n * | |\r\n * | (cancellation sent) |\r\n * V |\r\n * (deleted) <---------------------------+\r\n * ```\r\n */\r\nexport enum RoomKeyRequestState {\r\n /** request not yet sent */\r\n Unsent,\r\n /** request sent, awaiting reply */\r\n Sent,\r\n /** reply received, cancellation not yet sent */\r\n CancellationPending,\r\n /**\r\n * Cancellation not yet sent and will transition to UNSENT instead of\r\n * being deleted once the cancellation has been sent.\r\n */\r\n CancellationPendingAndWillResend,\r\n}\r\n\r\n/* eslint-disable camelcase */\r\ninterface IRoomKey {\r\n room_id: string;\r\n algorithm: string;\r\n}\r\n\r\n/**\r\n * The parameters of a room key request. The details of the request may\r\n * vary with the crypto algorithm, but the management and storage layers for\r\n * outgoing requests expect it to have 'room_id' and 'session_id' properties.\r\n */\r\nexport interface IRoomKeyRequestBody extends IRoomKey {\r\n session_id: string;\r\n sender_key: string;\r\n}\r\n\r\n/* eslint-enable camelcase */\r\n\r\nexport interface IRoomKeyRequestRecipient {\r\n userId: string;\r\n deviceId: string;\r\n}\r\n\r\ninterface IDevice {\r\n keys: Record<string, string>;\r\n algorithms: string[];\r\n verified: DeviceVerification;\r\n known: boolean;\r\n unsigned?: Record<string, any>;\r\n signatures?: ISignatures;\r\n}\r\n\r\n/** State of the verification of the device. */\r\nexport enum DeviceVerification {\r\n Blocked = -1,\r\n Unverified = 0,\r\n Verified = 1,\r\n}\r\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAOA;AACA;AACA;;AAMA;AACA;AACA;;AAqIA;;AAOA;;AAKA;;AA4BA;AACA;AACA;;AA0BA;AACA;AACA;AACA;AACA;AACA,OAAO,IAAMA,kCAAkC,GAAG,gBAAgB;;AAElE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAYC,cAAc,0BAAdA,cAAc;EACtB;EADQA,cAAc,CAAdA,cAAc;EAItB;EAJQA,cAAc,CAAdA,cAAc;EAOtB;EAPQA,cAAc,CAAdA,cAAc;EAUtB;EAVQA,cAAc,CAAdA,cAAc;EAatB;EAbQA,cAAc,CAAdA,cAAc;EAgBtB;AACJ;EAjBYA,cAAc,CAAdA,cAAc;EAAA,OAAdA,cAAc;AAAA;;AAqB1B;AACA;AACA;AACA;AACA,OAAO,IAAMC,kBAAkB,GAAG,EAAE;;AAqBpC;;AAMA;;AAEA,WAAYC,cAAc,0BAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAA,OAAdA,cAAc;AAAA;;AAO1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAYC,mBAAmB,0BAAnBA,mBAAmB;EAC3B;EADQA,mBAAmB,CAAnBA,mBAAmB;EAG3B;EAHQA,mBAAmB,CAAnBA,mBAAmB;EAK3B;EALQA,mBAAmB,CAAnBA,mBAAmB;EAO3B;AACJ;AACA;AACA;EAVYA,mBAAmB,CAAnBA,mBAAmB;EAAA,OAAnBA,mBAAmB;AAAA;;AAc/B;;AAMA;AACA;AACA;AACA;AACA;;AAMA;;AAgBA;AACA,WAAYC,kBAAkB,0BAAlBA,kBAAkB;EAAlBA,kBAAkB,CAAlBA,kBAAkB;EAAlBA,kBAAkB,CAAlBA,kBAAkB;EAAlBA,kBAAkB,CAAlBA,kBAAkB;EAAA,OAAlBA,kBAAkB;AAAA","ignoreList":[]}
1
+ {"version":3,"file":"base.js","names":["ACCOUNT_OBJECT_KEY_MIGRATION_STATE","MigrationState","SESSION_BATCH_SIZE","TrackingStatus","RoomKeyRequestState","DeviceVerification"],"sources":["../../../src/crypto/store/base.ts"],"sourcesContent":["/*\nCopyright 2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport { type Logger } from \"../../logger.ts\";\nimport { type CrossSigningKeyInfo } from \"../../crypto-api/index.ts\";\nimport { type AESEncryptedSecretStoragePayload } from \"../../@types/AESEncryptedSecretStoragePayload.ts\";\nimport { type ISignatures } from \"../../@types/signed.ts\";\n\n/**\n * Internal module. Definitions for storage for the crypto module\n */\n\nexport interface SecretStorePrivateKeys {\n \"m.megolm_backup.v1\": AESEncryptedSecretStoragePayload;\n}\n\n/**\n * Abstraction of things that can store data required for end-to-end encryption\n */\nexport interface CryptoStore {\n /**\n * Returns true if this CryptoStore has ever been initialised (ie, it might contain data).\n *\n * Unlike the rest of the methods in this interface, can be called before {@link CryptoStore#startup}.\n *\n * @internal\n */\n containsData(): Promise<boolean>;\n\n /**\n * Initialise this crypto store.\n *\n * Typically, this involves provisioning storage, and migrating any existing data to the current version of the\n * storage schema where appropriate.\n *\n * Must be called before any of the rest of the methods in this interface.\n */\n startup(): Promise<CryptoStore>;\n\n deleteAllData(): Promise<void>;\n\n /**\n * Get data on how much of the libolm to Rust Crypto migration has been done.\n *\n * @internal\n */\n getMigrationState(): Promise<MigrationState>;\n\n /**\n * Set data on how much of the libolm to Rust Crypto migration has been done.\n *\n * @internal\n */\n setMigrationState(migrationState: MigrationState): Promise<void>;\n\n // Olm Account\n getAccount(txn: unknown, func: (accountPickle: string | null) => void): void;\n storeAccount(txn: unknown, accountPickle: string): void;\n getCrossSigningKeys(txn: unknown, func: (keys: Record<string, CrossSigningKeyInfo> | null) => void): void;\n getSecretStorePrivateKey<K extends keyof SecretStorePrivateKeys>(\n txn: unknown,\n func: (key: SecretStorePrivateKeys[K] | null) => void,\n type: K,\n ): void;\n storeSecretStorePrivateKey<K extends keyof SecretStorePrivateKeys>(\n txn: unknown,\n type: K,\n key: SecretStorePrivateKeys[K],\n ): void;\n\n // Olm Sessions\n countEndToEndSessions(txn: unknown, func: (count: number) => void): void;\n getEndToEndSession(\n deviceKey: string,\n sessionId: string,\n txn: unknown,\n func: (session: ISessionInfo | null) => void,\n ): void;\n getEndToEndSessions(\n deviceKey: string,\n txn: unknown,\n func: (sessions: { [sessionId: string]: ISessionInfo }) => void,\n ): void;\n\n storeEndToEndSession(deviceKey: string, sessionId: string, sessionInfo: ISessionInfo, txn: unknown): void;\n\n /**\n * Get a batch of end-to-end sessions from the database.\n *\n * @returns A batch of Olm Sessions, or `null` if no sessions are left.\n * @internal\n */\n getEndToEndSessionsBatch(): Promise<ISessionInfo[] | null>;\n\n /**\n * Delete a batch of end-to-end sessions from the database.\n *\n * Any sessions in the list which are not found are silently ignored.\n *\n * @internal\n */\n deleteEndToEndSessionsBatch(sessions: { deviceKey?: string; sessionId?: string }[]): Promise<void>;\n\n // Inbound Group Sessions\n getEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n txn: unknown,\n func: (groupSession: InboundGroupSessionData | null, groupSessionWithheld: IWithheld | null) => void,\n ): void;\n storeEndToEndInboundGroupSession(\n senderCurve25519Key: string,\n sessionId: string,\n sessionData: InboundGroupSessionData,\n txn: unknown,\n ): void;\n\n /**\n * Count the number of Megolm sessions in the database.\n *\n * @internal\n */\n countEndToEndInboundGroupSessions(): Promise<number>;\n\n /**\n * Get a batch of Megolm sessions from the database.\n *\n * @returns A batch of Megolm Sessions, or `null` if no sessions are left.\n * @internal\n */\n getEndToEndInboundGroupSessionsBatch(): Promise<SessionExtended[] | null>;\n\n /**\n * Delete a batch of Megolm sessions from the database.\n *\n * Any sessions in the list which are not found are silently ignored.\n *\n * @internal\n */\n deleteEndToEndInboundGroupSessionsBatch(sessions: { senderKey: string; sessionId: string }[]): Promise<void>;\n\n // Device Data\n getEndToEndRooms(txn: unknown, func: (rooms: Record<string, IRoomEncryption>) => void): void;\n markSessionsNeedingBackup(sessions: ISession[], txn?: unknown): Promise<void>;\n\n // Session key backups\n doTxn<T>(mode: Mode, stores: Iterable<string>, func: (txn: unknown) => T, log?: Logger): Promise<T>;\n}\n\nexport type Mode = \"readonly\" | \"readwrite\";\n\n/** Data on a Megolm session */\nexport interface ISession {\n senderKey: string;\n sessionId: string;\n sessionData?: InboundGroupSessionData;\n}\n\n/** Extended data on a Megolm session */\nexport interface SessionExtended extends ISession {\n needsBackup: boolean;\n}\n\n/** Data on an Olm session */\nexport interface ISessionInfo {\n deviceKey?: string;\n sessionId?: string;\n session?: string;\n lastReceivedMessageTs?: number;\n}\n\nexport interface IDeviceData {\n devices: {\n [userId: string]: {\n [deviceId: string]: IDevice;\n };\n };\n trackingStatus: {\n [userId: string]: TrackingStatus;\n };\n crossSigningInfo?: Record<string, ICrossSigningInfo>;\n syncToken?: string;\n}\n\nexport interface IWithheld {\n // eslint-disable-next-line camelcase\n room_id: string;\n code: string;\n reason: string;\n}\n\n/**\n * Represents an outgoing room key request\n */\nexport interface OutgoingRoomKeyRequest {\n /**\n * Unique id for this request. Used for both an id within the request for later pairing with a cancellation,\n * and for the transaction id when sending the to_device messages to our local server.\n */\n requestId: string;\n requestTxnId?: string;\n /**\n * Transaction id for the cancellation, if any\n */\n cancellationTxnId?: string;\n /**\n * List of recipients for the request\n */\n recipients: IRoomKeyRequestRecipient[];\n /**\n * Parameters for the request\n */\n requestBody: IRoomKeyRequestBody;\n /**\n * current state of this request\n */\n state: RoomKeyRequestState;\n}\n\n/**\n * Keys for the `account` object store to store the migration state.\n * Values are defined in `MigrationState`.\n * @internal\n */\nexport const ACCOUNT_OBJECT_KEY_MIGRATION_STATE = \"migrationState\";\n\n/**\n * A record of which steps have been completed in the libolm to Rust Crypto migration.\n *\n * Used by {@link CryptoStore#getMigrationState} and {@link CryptoStore#setMigrationState}.\n *\n * @internal\n */\nexport enum MigrationState {\n /** No migration steps have yet been completed. */\n NOT_STARTED,\n\n /** We have migrated the account data, cross-signing keys, etc. */\n INITIAL_DATA_MIGRATED,\n\n /** INITIAL_DATA_MIGRATED, and in addition, we have migrated all the Olm sessions. */\n OLM_SESSIONS_MIGRATED,\n\n /** OLM_SESSIONS_MIGRATED, and in addition, we have migrated all the Megolm sessions. */\n MEGOLM_SESSIONS_MIGRATED,\n\n /** MEGOLM_SESSIONS_MIGRATED, and in addition, we have migrated all the room settings. */\n ROOM_SETTINGS_MIGRATED,\n\n /** ROOM_SETTINGS_MIGRATED, and in addition, we have done the first own keys query in order to\n * load the public part of the keys that have been migrated */\n INITIAL_OWN_KEY_QUERY_DONE,\n}\n\n/**\n * The size of batches to be returned by {@link CryptoStore#getEndToEndSessionsBatch} and\n * {@link CryptoStore#getEndToEndInboundGroupSessionsBatch}.\n */\nexport const SESSION_BATCH_SIZE = 50;\n\nexport interface InboundGroupSessionData {\n room_id: string; // eslint-disable-line camelcase\n /** pickled Olm.InboundGroupSession */\n session: string;\n keysClaimed?: Record<string, string>;\n /** Devices involved in forwarding this session to us (normally empty). */\n forwardingCurve25519KeyChain: string[];\n /** whether this session is untrusted. */\n untrusted?: boolean;\n /** whether this session exists during the room being set to shared history. */\n sharedHistory?: boolean;\n}\n\nexport interface ICrossSigningInfo {\n keys: Record<string, CrossSigningKeyInfo>;\n firstUse: boolean;\n crossSigningVerifiedBefore: boolean;\n}\n\n/* eslint-disable camelcase */\nexport interface IRoomEncryption {\n algorithm: string;\n rotation_period_ms?: number;\n rotation_period_msgs?: number;\n}\n/* eslint-enable camelcase */\n\nexport enum TrackingStatus {\n NotTracked,\n PendingDownload,\n DownloadInProgress,\n UpToDate,\n}\n\n/**\n * possible states for a room key request\n *\n * The state machine looks like:\n * ```\n *\n * | (cancellation sent)\n * | .-------------------------------------------------.\n * | | |\n * V V (cancellation requested) |\n * UNSENT -----------------------------+ |\n * | | |\n * | | |\n * | (send successful) | CANCELLATION_PENDING_AND_WILL_RESEND\n * V | Λ\n * SENT | |\n * |-------------------------------- | --------------'\n * | | (cancellation requested with intent\n * | | to resend the original request)\n * | |\n * | (cancellation requested) |\n * V |\n * CANCELLATION_PENDING |\n * | |\n * | (cancellation sent) |\n * V |\n * (deleted) <---------------------------+\n * ```\n */\nexport enum RoomKeyRequestState {\n /** request not yet sent */\n Unsent,\n /** request sent, awaiting reply */\n Sent,\n /** reply received, cancellation not yet sent */\n CancellationPending,\n /**\n * Cancellation not yet sent and will transition to UNSENT instead of\n * being deleted once the cancellation has been sent.\n */\n CancellationPendingAndWillResend,\n}\n\n/* eslint-disable camelcase */\ninterface IRoomKey {\n room_id: string;\n algorithm: string;\n}\n\n/**\n * The parameters of a room key request. The details of the request may\n * vary with the crypto algorithm, but the management and storage layers for\n * outgoing requests expect it to have 'room_id' and 'session_id' properties.\n */\nexport interface IRoomKeyRequestBody extends IRoomKey {\n session_id: string;\n sender_key: string;\n}\n\n/* eslint-enable camelcase */\n\nexport interface IRoomKeyRequestRecipient {\n userId: string;\n deviceId: string;\n}\n\ninterface IDevice {\n keys: Record<string, string>;\n algorithms: string[];\n verified: DeviceVerification;\n known: boolean;\n unsigned?: Record<string, any>;\n signatures?: ISignatures;\n}\n\n/** State of the verification of the device. */\nexport enum DeviceVerification {\n Blocked = -1,\n Unverified = 0,\n Verified = 1,\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAOA;AACA;AACA;;AAMA;AACA;AACA;;AAqIA;;AAOA;;AAKA;;AA4BA;AACA;AACA;;AA0BA;AACA;AACA;AACA;AACA;AACA,OAAO,IAAMA,kCAAkC,GAAG,gBAAgB;;AAElE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAYC,cAAc,0BAAdA,cAAc;EACtB;EADQA,cAAc,CAAdA,cAAc;EAItB;EAJQA,cAAc,CAAdA,cAAc;EAOtB;EAPQA,cAAc,CAAdA,cAAc;EAUtB;EAVQA,cAAc,CAAdA,cAAc;EAatB;EAbQA,cAAc,CAAdA,cAAc;EAgBtB;AACJ;EAjBYA,cAAc,CAAdA,cAAc;EAAA,OAAdA,cAAc;AAAA;;AAqB1B;AACA;AACA;AACA;AACA,OAAO,IAAMC,kBAAkB,GAAG,EAAE;;AAqBpC;;AAMA;;AAEA,WAAYC,cAAc,0BAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAdA,cAAc,CAAdA,cAAc;EAAA,OAAdA,cAAc;AAAA;;AAO1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAYC,mBAAmB,0BAAnBA,mBAAmB;EAC3B;EADQA,mBAAmB,CAAnBA,mBAAmB;EAG3B;EAHQA,mBAAmB,CAAnBA,mBAAmB;EAK3B;EALQA,mBAAmB,CAAnBA,mBAAmB;EAO3B;AACJ;AACA;AACA;EAVYA,mBAAmB,CAAnBA,mBAAmB;EAAA,OAAnBA,mBAAmB;AAAA;;AAc/B;;AAMA;AACA;AACA;AACA;AACA;;AAMA;;AAgBA;AACA,WAAYC,kBAAkB,0BAAlBA,kBAAkB;EAAlBA,kBAAkB,CAAlBA,kBAAkB;EAAlBA,kBAAkB,CAAlBA,kBAAkB;EAAlBA,kBAAkB,CAAlBA,kBAAkB;EAAA,OAAlBA,kBAAkB;AAAA","ignoreList":[]}
@@ -1,19 +1,19 @@
1
1
  import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
2
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
- /*
4
- Copyright 2017 - 2021 The Matrix.org Foundation C.I.C.
5
-
6
- Licensed under the Apache License, Version 2.0 (the "License");
7
- you may not use this file except in compliance with the License.
8
- You may obtain a copy of the License at
9
-
10
- http://www.apache.org/licenses/LICENSE-2.0
11
-
12
- Unless required by applicable law or agreed to in writing, software
13
- distributed under the License is distributed on an "AS IS" BASIS,
14
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- See the License for the specific language governing permissions and
16
- limitations under the License.
3
+ /*
4
+ Copyright 2017 - 2021 The Matrix.org Foundation C.I.C.
5
+
6
+ Licensed under the Apache License, Version 2.0 (the "License");
7
+ you may not use this file except in compliance with the License.
8
+ You may obtain a copy of the License at
9
+
10
+ http://www.apache.org/licenses/LICENSE-2.0
11
+
12
+ Unless required by applicable law or agreed to in writing, software
13
+ distributed under the License is distributed on an "AS IS" BASIS,
14
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
+ See the License for the specific language governing permissions and
16
+ limitations under the License.
17
17
  */
18
18
 
19
19
  import { logger } from "../../logger.js";
@@ -21,15 +21,15 @@ import { MigrationState, SESSION_BATCH_SIZE, ACCOUNT_OBJECT_KEY_MIGRATION_STATE
21
21
  import { IndexedDBCryptoStore } from "./indexeddb-crypto-store.js";
22
22
  var PROFILE_TRANSACTIONS = false;
23
23
 
24
- /**
25
- * Implementation of a CryptoStore which is backed by an existing
26
- * IndexedDB connection. Generally you want IndexedDBCryptoStore
27
- * which connects to the database and defers to one of these.
28
- *
29
- * @internal
24
+ /**
25
+ * Implementation of a CryptoStore which is backed by an existing
26
+ * IndexedDB connection. Generally you want IndexedDBCryptoStore
27
+ * which connects to the database and defers to one of these.
28
+ *
29
+ * @internal
30
30
  */
31
31
  export class Backend {
32
- /**
32
+ /**
33
33
  */
34
34
  constructor(db) {
35
35
  this.db = db;
@@ -61,10 +61,10 @@ export class Backend {
61
61
  })();
62
62
  }
63
63
 
64
- /**
65
- * Get data on how much of the libolm to Rust Crypto migration has been done.
66
- *
67
- * Implementation of {@link CryptoStore.getMigrationState}.
64
+ /**
65
+ * Get data on how much of the libolm to Rust Crypto migration has been done.
66
+ *
67
+ * Implementation of {@link CryptoStore.getMigrationState}.
68
68
  */
69
69
  getMigrationState() {
70
70
  var _this2 = this;
@@ -82,10 +82,10 @@ export class Backend {
82
82
  })();
83
83
  }
84
84
 
85
- /**
86
- * Set data on how much of the libolm to Rust Crypto migration has been done.
87
- *
88
- * Implementation of {@link CryptoStore.setMigrationState}.
85
+ /**
86
+ * Set data on how much of the libolm to Rust Crypto migration has been done.
87
+ *
88
+ * Implementation of {@link CryptoStore.setMigrationState}.
89
89
  */
90
90
  setMigrationState(migrationState) {
91
91
  var _this3 = this;
@@ -204,10 +204,10 @@ export class Backend {
204
204
  });
205
205
  }
206
206
 
207
- /**
208
- * Fetch a batch of Olm sessions from the database.
209
- *
210
- * Implementation of {@link CryptoStore.getEndToEndSessionsBatch}.
207
+ /**
208
+ * Fetch a batch of Olm sessions from the database.
209
+ *
210
+ * Implementation of {@link CryptoStore.getEndToEndSessionsBatch}.
211
211
  */
212
212
  getEndToEndSessionsBatch() {
213
213
  var _this4 = this;
@@ -238,12 +238,12 @@ export class Backend {
238
238
  })();
239
239
  }
240
240
 
241
- /**
242
- * Delete a batch of Olm sessions from the database.
243
- *
244
- * Implementation of {@link CryptoStore.deleteEndToEndSessionsBatch}.
245
- *
246
- * @internal
241
+ /**
242
+ * Delete a batch of Olm sessions from the database.
243
+ *
244
+ * Implementation of {@link CryptoStore.deleteEndToEndSessionsBatch}.
245
+ *
246
+ * @internal
247
247
  */
248
248
  deleteEndToEndSessionsBatch(sessions) {
249
249
  var _this5 = this;
@@ -322,12 +322,12 @@ export class Backend {
322
322
  });
323
323
  }
324
324
 
325
- /**
326
- * Count the number of Megolm sessions in the database.
327
- *
328
- * Implementation of {@link CryptoStore.countEndToEndInboundGroupSessions}.
329
- *
330
- * @internal
325
+ /**
326
+ * Count the number of Megolm sessions in the database.
327
+ *
328
+ * Implementation of {@link CryptoStore.countEndToEndInboundGroupSessions}.
329
+ *
330
+ * @internal
331
331
  */
332
332
  countEndToEndInboundGroupSessions() {
333
333
  var _this6 = this;
@@ -344,10 +344,10 @@ export class Backend {
344
344
  })();
345
345
  }
346
346
 
347
- /**
348
- * Fetch a batch of Megolm sessions from the database.
349
- *
350
- * Implementation of {@link CryptoStore.getEndToEndInboundGroupSessionsBatch}.
347
+ /**
348
+ * Fetch a batch of Megolm sessions from the database.
349
+ *
350
+ * Implementation of {@link CryptoStore.getEndToEndInboundGroupSessionsBatch}.
351
351
  */
352
352
  getEndToEndInboundGroupSessionsBatch() {
353
353
  var _this7 = this;
@@ -387,12 +387,12 @@ export class Backend {
387
387
  })();
388
388
  }
389
389
 
390
- /**
391
- * Delete a batch of Megolm sessions from the database.
392
- *
393
- * Implementation of {@link CryptoStore.deleteEndToEndInboundGroupSessionsBatch}.
394
- *
395
- * @internal
390
+ /**
391
+ * Delete a batch of Megolm sessions from the database.
392
+ *
393
+ * Implementation of {@link CryptoStore.deleteEndToEndInboundGroupSessionsBatch}.
394
+ *
395
+ * @internal
396
396
  */
397
397
  deleteEndToEndInboundGroupSessionsBatch(sessions) {
398
398
  var _this8 = this;
@@ -559,9 +559,9 @@ function createDatabase(db) {
559
559
  outgoingRoomKeyRequestsStore.createIndex("session", ["requestBody.room_id", "requestBody.session_id"]);
560
560
  outgoingRoomKeyRequestsStore.createIndex("state", "state");
561
561
  }
562
- /*
563
- * Aborts a transaction with a given exception
564
- * The transaction promise will be rejected with this exception.
562
+ /*
563
+ * Aborts a transaction with a given exception
564
+ * The transaction promise will be rejected with this exception.
565
565
  */
566
566
  function abortWithException(txn, e) {
567
567
  // We cheekily stick our exception onto the transaction object here