@unwanted/matrix-sdk-mini 34.12.0-1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1203) hide show
  1. package/CHANGELOG.md +5910 -0
  2. package/LICENSE +177 -0
  3. package/README.md +459 -0
  4. package/git-revision.txt +1 -0
  5. package/lib/@types/AESEncryptedSecretStoragePayload.d.ts +14 -0
  6. package/lib/@types/AESEncryptedSecretStoragePayload.d.ts.map +1 -0
  7. package/lib/@types/AESEncryptedSecretStoragePayload.js +1 -0
  8. package/lib/@types/AESEncryptedSecretStoragePayload.js.map +1 -0
  9. package/lib/@types/IIdentityServerProvider.d.ts +9 -0
  10. package/lib/@types/IIdentityServerProvider.d.ts.map +1 -0
  11. package/lib/@types/IIdentityServerProvider.js +1 -0
  12. package/lib/@types/IIdentityServerProvider.js.map +1 -0
  13. package/lib/@types/PushRules.d.ts +140 -0
  14. package/lib/@types/PushRules.d.ts.map +1 -0
  15. package/lib/@types/PushRules.js +94 -0
  16. package/lib/@types/PushRules.js.map +1 -0
  17. package/lib/@types/another-json.d.js +0 -0
  18. package/lib/@types/another-json.d.js.map +1 -0
  19. package/lib/@types/auth.d.ts +208 -0
  20. package/lib/@types/auth.d.ts.map +1 -0
  21. package/lib/@types/auth.js +99 -0
  22. package/lib/@types/auth.js.map +1 -0
  23. package/lib/@types/beacon.d.ts +106 -0
  24. package/lib/@types/beacon.d.ts.map +1 -0
  25. package/lib/@types/beacon.js +119 -0
  26. package/lib/@types/beacon.js.map +1 -0
  27. package/lib/@types/common.d.ts +9 -0
  28. package/lib/@types/common.d.ts.map +1 -0
  29. package/lib/@types/common.js +1 -0
  30. package/lib/@types/common.js.map +1 -0
  31. package/lib/@types/crypto.d.ts +47 -0
  32. package/lib/@types/crypto.d.ts.map +1 -0
  33. package/lib/@types/crypto.js +1 -0
  34. package/lib/@types/crypto.js.map +1 -0
  35. package/lib/@types/event.d.ts +258 -0
  36. package/lib/@types/event.d.ts.map +1 -0
  37. package/lib/@types/event.js +239 -0
  38. package/lib/@types/event.js.map +1 -0
  39. package/lib/@types/events.d.ts +92 -0
  40. package/lib/@types/events.d.ts.map +1 -0
  41. package/lib/@types/events.js +1 -0
  42. package/lib/@types/events.js.map +1 -0
  43. package/lib/@types/extensible_events.d.ts +98 -0
  44. package/lib/@types/extensible_events.d.ts.map +1 -0
  45. package/lib/@types/extensible_events.js +116 -0
  46. package/lib/@types/extensible_events.js.map +1 -0
  47. package/lib/@types/global.d.js +20 -0
  48. package/lib/@types/global.d.js.map +1 -0
  49. package/lib/@types/local_notifications.d.ts +4 -0
  50. package/lib/@types/local_notifications.d.ts.map +1 -0
  51. package/lib/@types/local_notifications.js +1 -0
  52. package/lib/@types/local_notifications.js.map +1 -0
  53. package/lib/@types/location.d.ts +60 -0
  54. package/lib/@types/location.d.ts.map +1 -0
  55. package/lib/@types/location.js +67 -0
  56. package/lib/@types/location.js.map +1 -0
  57. package/lib/@types/matrix-sdk-crypto-wasm.d.js +1 -0
  58. package/lib/@types/matrix-sdk-crypto-wasm.d.js.map +1 -0
  59. package/lib/@types/media.d.ts +220 -0
  60. package/lib/@types/media.d.ts.map +1 -0
  61. package/lib/@types/media.js +1 -0
  62. package/lib/@types/media.js.map +1 -0
  63. package/lib/@types/membership.d.ts +41 -0
  64. package/lib/@types/membership.d.ts.map +1 -0
  65. package/lib/@types/membership.js +37 -0
  66. package/lib/@types/membership.js.map +1 -0
  67. package/lib/@types/oidc-client-ts.d.js +18 -0
  68. package/lib/@types/oidc-client-ts.d.js.map +1 -0
  69. package/lib/@types/partials.d.ts +39 -0
  70. package/lib/@types/partials.d.ts.map +1 -0
  71. package/lib/@types/partials.js +53 -0
  72. package/lib/@types/partials.js.map +1 -0
  73. package/lib/@types/polls.d.ts +88 -0
  74. package/lib/@types/polls.d.ts.map +1 -0
  75. package/lib/@types/polls.js +86 -0
  76. package/lib/@types/polls.js.map +1 -0
  77. package/lib/@types/read_receipts.d.ts +36 -0
  78. package/lib/@types/read_receipts.d.ts.map +1 -0
  79. package/lib/@types/read_receipts.js +27 -0
  80. package/lib/@types/read_receipts.js.map +1 -0
  81. package/lib/@types/registration.d.ts +85 -0
  82. package/lib/@types/registration.d.ts.map +1 -0
  83. package/lib/@types/registration.js +1 -0
  84. package/lib/@types/registration.js.map +1 -0
  85. package/lib/@types/requests.d.ts +241 -0
  86. package/lib/@types/requests.d.ts.map +1 -0
  87. package/lib/@types/requests.js +28 -0
  88. package/lib/@types/requests.js.map +1 -0
  89. package/lib/@types/search.d.ts +90 -0
  90. package/lib/@types/search.d.ts.map +1 -0
  91. package/lib/@types/search.js +30 -0
  92. package/lib/@types/search.js.map +1 -0
  93. package/lib/@types/signed.d.ts +9 -0
  94. package/lib/@types/signed.d.ts.map +1 -0
  95. package/lib/@types/signed.js +1 -0
  96. package/lib/@types/signed.js.map +1 -0
  97. package/lib/@types/spaces.d.ts +16 -0
  98. package/lib/@types/spaces.d.ts.map +1 -0
  99. package/lib/@types/spaces.js +1 -0
  100. package/lib/@types/spaces.js.map +1 -0
  101. package/lib/@types/state_events.d.ts +116 -0
  102. package/lib/@types/state_events.d.ts.map +1 -0
  103. package/lib/@types/state_events.js +1 -0
  104. package/lib/@types/state_events.js.map +1 -0
  105. package/lib/@types/synapse.d.ts +19 -0
  106. package/lib/@types/synapse.d.ts.map +1 -0
  107. package/lib/@types/synapse.js +1 -0
  108. package/lib/@types/synapse.js.map +1 -0
  109. package/lib/@types/sync.d.ts +8 -0
  110. package/lib/@types/sync.d.ts.map +1 -0
  111. package/lib/@types/sync.js +25 -0
  112. package/lib/@types/sync.js.map +1 -0
  113. package/lib/@types/threepids.d.ts +12 -0
  114. package/lib/@types/threepids.d.ts.map +1 -0
  115. package/lib/@types/threepids.js +24 -0
  116. package/lib/@types/threepids.js.map +1 -0
  117. package/lib/@types/topic.d.ts +48 -0
  118. package/lib/@types/topic.d.ts.map +1 -0
  119. package/lib/@types/topic.js +57 -0
  120. package/lib/@types/topic.js.map +1 -0
  121. package/lib/@types/uia.d.ts +12 -0
  122. package/lib/@types/uia.d.ts.map +1 -0
  123. package/lib/@types/uia.js +1 -0
  124. package/lib/@types/uia.js.map +1 -0
  125. package/lib/NamespacedValue.d.ts +33 -0
  126. package/lib/NamespacedValue.d.ts.map +1 -0
  127. package/lib/NamespacedValue.js +113 -0
  128. package/lib/NamespacedValue.js.map +1 -0
  129. package/lib/ReEmitter.d.ts +15 -0
  130. package/lib/ReEmitter.d.ts.map +1 -0
  131. package/lib/ReEmitter.js +87 -0
  132. package/lib/ReEmitter.js.map +1 -0
  133. package/lib/ToDeviceMessageQueue.d.ts +28 -0
  134. package/lib/ToDeviceMessageQueue.d.ts.map +1 -0
  135. package/lib/ToDeviceMessageQueue.js +135 -0
  136. package/lib/ToDeviceMessageQueue.js.map +1 -0
  137. package/lib/autodiscovery.d.ts +136 -0
  138. package/lib/autodiscovery.d.ts.map +1 -0
  139. package/lib/autodiscovery.js +464 -0
  140. package/lib/autodiscovery.js.map +1 -0
  141. package/lib/base64.d.ts +28 -0
  142. package/lib/base64.d.ts.map +1 -0
  143. package/lib/base64.js +88 -0
  144. package/lib/base64.js.map +1 -0
  145. package/lib/browser-index.d.ts +8 -0
  146. package/lib/browser-index.d.ts.map +1 -0
  147. package/lib/browser-index.js +35 -0
  148. package/lib/browser-index.js.map +1 -0
  149. package/lib/client.d.ts +4232 -0
  150. package/lib/client.d.ts.map +1 -0
  151. package/lib/client.js +8622 -0
  152. package/lib/client.js.map +1 -0
  153. package/lib/common-crypto/CryptoBackend.d.ts +240 -0
  154. package/lib/common-crypto/CryptoBackend.d.ts.map +1 -0
  155. package/lib/common-crypto/CryptoBackend.js +73 -0
  156. package/lib/common-crypto/CryptoBackend.js.map +1 -0
  157. package/lib/common-crypto/key-passphrase.d.ts +14 -0
  158. package/lib/common-crypto/key-passphrase.d.ts.map +1 -0
  159. package/lib/common-crypto/key-passphrase.js +33 -0
  160. package/lib/common-crypto/key-passphrase.js.map +1 -0
  161. package/lib/content-helpers.d.ts +90 -0
  162. package/lib/content-helpers.d.ts.map +1 -0
  163. package/lib/content-helpers.js +250 -0
  164. package/lib/content-helpers.js.map +1 -0
  165. package/lib/content-repo.d.ts +24 -0
  166. package/lib/content-repo.d.ts.map +1 -0
  167. package/lib/content-repo.js +104 -0
  168. package/lib/content-repo.js.map +1 -0
  169. package/lib/crypto/CrossSigning.d.ts +184 -0
  170. package/lib/crypto/CrossSigning.d.ts.map +1 -0
  171. package/lib/crypto/CrossSigning.js +718 -0
  172. package/lib/crypto/CrossSigning.js.map +1 -0
  173. package/lib/crypto/DeviceList.d.ts +216 -0
  174. package/lib/crypto/DeviceList.d.ts.map +1 -0
  175. package/lib/crypto/DeviceList.js +892 -0
  176. package/lib/crypto/DeviceList.js.map +1 -0
  177. package/lib/crypto/EncryptionSetup.d.ts +152 -0
  178. package/lib/crypto/EncryptionSetup.d.ts.map +1 -0
  179. package/lib/crypto/EncryptionSetup.js +356 -0
  180. package/lib/crypto/EncryptionSetup.js.map +1 -0
  181. package/lib/crypto/OlmDevice.d.ts +457 -0
  182. package/lib/crypto/OlmDevice.d.ts.map +1 -0
  183. package/lib/crypto/OlmDevice.js +1241 -0
  184. package/lib/crypto/OlmDevice.js.map +1 -0
  185. package/lib/crypto/OutgoingRoomKeyRequestManager.d.ts +109 -0
  186. package/lib/crypto/OutgoingRoomKeyRequestManager.d.ts.map +1 -0
  187. package/lib/crypto/OutgoingRoomKeyRequestManager.js +415 -0
  188. package/lib/crypto/OutgoingRoomKeyRequestManager.js.map +1 -0
  189. package/lib/crypto/RoomList.d.ts +26 -0
  190. package/lib/crypto/RoomList.d.ts.map +1 -0
  191. package/lib/crypto/RoomList.js +71 -0
  192. package/lib/crypto/RoomList.js.map +1 -0
  193. package/lib/crypto/SecretSharing.d.ts +24 -0
  194. package/lib/crypto/SecretSharing.d.ts.map +1 -0
  195. package/lib/crypto/SecretSharing.js +194 -0
  196. package/lib/crypto/SecretSharing.js.map +1 -0
  197. package/lib/crypto/SecretStorage.d.ts +55 -0
  198. package/lib/crypto/SecretStorage.d.ts.map +1 -0
  199. package/lib/crypto/SecretStorage.js +118 -0
  200. package/lib/crypto/SecretStorage.js.map +1 -0
  201. package/lib/crypto/aes.d.ts +6 -0
  202. package/lib/crypto/aes.d.ts.map +1 -0
  203. package/lib/crypto/aes.js +24 -0
  204. package/lib/crypto/aes.js.map +1 -0
  205. package/lib/crypto/algorithms/base.d.ts +156 -0
  206. package/lib/crypto/algorithms/base.d.ts.map +1 -0
  207. package/lib/crypto/algorithms/base.js +187 -0
  208. package/lib/crypto/algorithms/base.js.map +1 -0
  209. package/lib/crypto/algorithms/index.d.ts +4 -0
  210. package/lib/crypto/algorithms/index.d.ts.map +1 -0
  211. package/lib/crypto/algorithms/index.js +20 -0
  212. package/lib/crypto/algorithms/index.js.map +1 -0
  213. package/lib/crypto/algorithms/megolm.d.ts +385 -0
  214. package/lib/crypto/algorithms/megolm.d.ts.map +1 -0
  215. package/lib/crypto/algorithms/megolm.js +1822 -0
  216. package/lib/crypto/algorithms/megolm.js.map +1 -0
  217. package/lib/crypto/algorithms/olm.d.ts +5 -0
  218. package/lib/crypto/algorithms/olm.d.ts.map +1 -0
  219. package/lib/crypto/algorithms/olm.js +299 -0
  220. package/lib/crypto/algorithms/olm.js.map +1 -0
  221. package/lib/crypto/api.d.ts +32 -0
  222. package/lib/crypto/api.d.ts.map +1 -0
  223. package/lib/crypto/api.js +22 -0
  224. package/lib/crypto/api.js.map +1 -0
  225. package/lib/crypto/backup.d.ts +227 -0
  226. package/lib/crypto/backup.d.ts.map +1 -0
  227. package/lib/crypto/backup.js +824 -0
  228. package/lib/crypto/backup.js.map +1 -0
  229. package/lib/crypto/crypto.d.ts +3 -0
  230. package/lib/crypto/crypto.d.ts.map +1 -0
  231. package/lib/crypto/crypto.js +19 -0
  232. package/lib/crypto/crypto.js.map +1 -0
  233. package/lib/crypto/dehydration.d.ts +34 -0
  234. package/lib/crypto/dehydration.d.ts.map +1 -0
  235. package/lib/crypto/dehydration.js +252 -0
  236. package/lib/crypto/dehydration.js.map +1 -0
  237. package/lib/crypto/device-converter.d.ts +9 -0
  238. package/lib/crypto/device-converter.d.ts.map +1 -0
  239. package/lib/crypto/device-converter.js +42 -0
  240. package/lib/crypto/device-converter.js.map +1 -0
  241. package/lib/crypto/deviceinfo.d.ts +99 -0
  242. package/lib/crypto/deviceinfo.d.ts.map +1 -0
  243. package/lib/crypto/deviceinfo.js +148 -0
  244. package/lib/crypto/deviceinfo.js.map +1 -0
  245. package/lib/crypto/index.d.ts +1209 -0
  246. package/lib/crypto/index.d.ts.map +1 -0
  247. package/lib/crypto/index.js +4097 -0
  248. package/lib/crypto/index.js.map +1 -0
  249. package/lib/crypto/key_passphrase.d.ts +14 -0
  250. package/lib/crypto/key_passphrase.d.ts.map +1 -0
  251. package/lib/crypto/key_passphrase.js +44 -0
  252. package/lib/crypto/key_passphrase.js.map +1 -0
  253. package/lib/crypto/keybackup.d.ts +18 -0
  254. package/lib/crypto/keybackup.d.ts.map +1 -0
  255. package/lib/crypto/keybackup.js +1 -0
  256. package/lib/crypto/keybackup.js.map +1 -0
  257. package/lib/crypto/olmlib.d.ts +129 -0
  258. package/lib/crypto/olmlib.d.ts.map +1 -0
  259. package/lib/crypto/olmlib.js +492 -0
  260. package/lib/crypto/olmlib.js.map +1 -0
  261. package/lib/crypto/recoverykey.d.ts +2 -0
  262. package/lib/crypto/recoverykey.d.ts.map +1 -0
  263. package/lib/crypto/recoverykey.js +19 -0
  264. package/lib/crypto/recoverykey.js.map +1 -0
  265. package/lib/crypto/store/base.d.ts +252 -0
  266. package/lib/crypto/store/base.d.ts.map +1 -0
  267. package/lib/crypto/store/base.js +64 -0
  268. package/lib/crypto/store/base.js.map +1 -0
  269. package/lib/crypto/store/indexeddb-crypto-store-backend.d.ts +187 -0
  270. package/lib/crypto/store/indexeddb-crypto-store-backend.d.ts.map +1 -0
  271. package/lib/crypto/store/indexeddb-crypto-store-backend.js +1145 -0
  272. package/lib/crypto/store/indexeddb-crypto-store-backend.js.map +1 -0
  273. package/lib/crypto/store/indexeddb-crypto-store.d.ts +432 -0
  274. package/lib/crypto/store/indexeddb-crypto-store.d.ts.map +1 -0
  275. package/lib/crypto/store/indexeddb-crypto-store.js +728 -0
  276. package/lib/crypto/store/indexeddb-crypto-store.js.map +1 -0
  277. package/lib/crypto/store/localStorage-crypto-store.d.ts +119 -0
  278. package/lib/crypto/store/localStorage-crypto-store.d.ts.map +1 -0
  279. package/lib/crypto/store/localStorage-crypto-store.js +531 -0
  280. package/lib/crypto/store/localStorage-crypto-store.js.map +1 -0
  281. package/lib/crypto/store/memory-crypto-store.d.ts +215 -0
  282. package/lib/crypto/store/memory-crypto-store.d.ts.map +1 -0
  283. package/lib/crypto/store/memory-crypto-store.js +622 -0
  284. package/lib/crypto/store/memory-crypto-store.js.map +1 -0
  285. package/lib/crypto/verification/Base.d.ts +105 -0
  286. package/lib/crypto/verification/Base.d.ts.map +1 -0
  287. package/lib/crypto/verification/Base.js +372 -0
  288. package/lib/crypto/verification/Base.js.map +1 -0
  289. package/lib/crypto/verification/Error.d.ts +35 -0
  290. package/lib/crypto/verification/Error.d.ts.map +1 -0
  291. package/lib/crypto/verification/Error.js +86 -0
  292. package/lib/crypto/verification/Error.js.map +1 -0
  293. package/lib/crypto/verification/IllegalMethod.d.ts +15 -0
  294. package/lib/crypto/verification/IllegalMethod.d.ts.map +1 -0
  295. package/lib/crypto/verification/IllegalMethod.js +43 -0
  296. package/lib/crypto/verification/IllegalMethod.js.map +1 -0
  297. package/lib/crypto/verification/QRCode.d.ts +51 -0
  298. package/lib/crypto/verification/QRCode.d.ts.map +1 -0
  299. package/lib/crypto/verification/QRCode.js +277 -0
  300. package/lib/crypto/verification/QRCode.js.map +1 -0
  301. package/lib/crypto/verification/SAS.d.ts +27 -0
  302. package/lib/crypto/verification/SAS.d.ts.map +1 -0
  303. package/lib/crypto/verification/SAS.js +485 -0
  304. package/lib/crypto/verification/SAS.js.map +1 -0
  305. package/lib/crypto/verification/SASDecimal.d.ts +8 -0
  306. package/lib/crypto/verification/SASDecimal.d.ts.map +1 -0
  307. package/lib/crypto/verification/SASDecimal.js +34 -0
  308. package/lib/crypto/verification/SASDecimal.js.map +1 -0
  309. package/lib/crypto/verification/request/Channel.d.ts +18 -0
  310. package/lib/crypto/verification/request/Channel.d.ts.map +1 -0
  311. package/lib/crypto/verification/request/Channel.js +1 -0
  312. package/lib/crypto/verification/request/Channel.js.map +1 -0
  313. package/lib/crypto/verification/request/InRoomChannel.d.ts +113 -0
  314. package/lib/crypto/verification/request/InRoomChannel.d.ts.map +1 -0
  315. package/lib/crypto/verification/request/InRoomChannel.js +351 -0
  316. package/lib/crypto/verification/request/InRoomChannel.js.map +1 -0
  317. package/lib/crypto/verification/request/ToDeviceChannel.d.ts +105 -0
  318. package/lib/crypto/verification/request/ToDeviceChannel.d.ts.map +1 -0
  319. package/lib/crypto/verification/request/ToDeviceChannel.js +328 -0
  320. package/lib/crypto/verification/request/ToDeviceChannel.js.map +1 -0
  321. package/lib/crypto/verification/request/VerificationRequest.d.ts +227 -0
  322. package/lib/crypto/verification/request/VerificationRequest.d.ts.map +1 -0
  323. package/lib/crypto/verification/request/VerificationRequest.js +937 -0
  324. package/lib/crypto/verification/request/VerificationRequest.js.map +1 -0
  325. package/lib/crypto-api/CryptoEvent.d.ts +69 -0
  326. package/lib/crypto-api/CryptoEvent.d.ts.map +1 -0
  327. package/lib/crypto-api/CryptoEvent.js +33 -0
  328. package/lib/crypto-api/CryptoEvent.js.map +1 -0
  329. package/lib/crypto-api/CryptoEventHandlerMap.d.ts +16 -0
  330. package/lib/crypto-api/CryptoEventHandlerMap.d.ts.map +1 -0
  331. package/lib/crypto-api/CryptoEventHandlerMap.js +22 -0
  332. package/lib/crypto-api/CryptoEventHandlerMap.js.map +1 -0
  333. package/lib/crypto-api/index.d.ts +978 -0
  334. package/lib/crypto-api/index.d.ts.map +1 -0
  335. package/lib/crypto-api/index.js +304 -0
  336. package/lib/crypto-api/index.js.map +1 -0
  337. package/lib/crypto-api/key-passphrase.d.ts +11 -0
  338. package/lib/crypto-api/key-passphrase.d.ts.map +1 -0
  339. package/lib/crypto-api/key-passphrase.js +51 -0
  340. package/lib/crypto-api/key-passphrase.js.map +1 -0
  341. package/lib/crypto-api/keybackup.d.ts +88 -0
  342. package/lib/crypto-api/keybackup.d.ts.map +1 -0
  343. package/lib/crypto-api/keybackup.js +1 -0
  344. package/lib/crypto-api/keybackup.js.map +1 -0
  345. package/lib/crypto-api/recovery-key.d.ts +11 -0
  346. package/lib/crypto-api/recovery-key.d.ts.map +1 -0
  347. package/lib/crypto-api/recovery-key.js +65 -0
  348. package/lib/crypto-api/recovery-key.js.map +1 -0
  349. package/lib/crypto-api/verification.d.ts +344 -0
  350. package/lib/crypto-api/verification.d.ts.map +1 -0
  351. package/lib/crypto-api/verification.js +91 -0
  352. package/lib/crypto-api/verification.js.map +1 -0
  353. package/lib/digest.d.ts +10 -0
  354. package/lib/digest.d.ts.map +1 -0
  355. package/lib/digest.js +40 -0
  356. package/lib/digest.js.map +1 -0
  357. package/lib/embedded.d.ts +143 -0
  358. package/lib/embedded.d.ts.map +1 -0
  359. package/lib/embedded.js +567 -0
  360. package/lib/embedded.js.map +1 -0
  361. package/lib/errors.d.ts +24 -0
  362. package/lib/errors.d.ts.map +1 -0
  363. package/lib/errors.js +51 -0
  364. package/lib/errors.js.map +1 -0
  365. package/lib/event-mapper.d.ts +10 -0
  366. package/lib/event-mapper.d.ts.map +1 -0
  367. package/lib/event-mapper.js +81 -0
  368. package/lib/event-mapper.js.map +1 -0
  369. package/lib/extensible_events_v1/ExtensibleEvent.d.ts +38 -0
  370. package/lib/extensible_events_v1/ExtensibleEvent.d.ts.map +1 -0
  371. package/lib/extensible_events_v1/ExtensibleEvent.js +57 -0
  372. package/lib/extensible_events_v1/ExtensibleEvent.js.map +1 -0
  373. package/lib/extensible_events_v1/InvalidEventError.d.ts +7 -0
  374. package/lib/extensible_events_v1/InvalidEventError.d.ts.map +1 -0
  375. package/lib/extensible_events_v1/InvalidEventError.js +25 -0
  376. package/lib/extensible_events_v1/InvalidEventError.js.map +1 -0
  377. package/lib/extensible_events_v1/MessageEvent.d.ts +45 -0
  378. package/lib/extensible_events_v1/MessageEvent.d.ts.map +1 -0
  379. package/lib/extensible_events_v1/MessageEvent.js +134 -0
  380. package/lib/extensible_events_v1/MessageEvent.js.map +1 -0
  381. package/lib/extensible_events_v1/PollEndEvent.d.ts +33 -0
  382. package/lib/extensible_events_v1/PollEndEvent.d.ts.map +1 -0
  383. package/lib/extensible_events_v1/PollEndEvent.js +88 -0
  384. package/lib/extensible_events_v1/PollEndEvent.js.map +1 -0
  385. package/lib/extensible_events_v1/PollResponseEvent.d.ts +49 -0
  386. package/lib/extensible_events_v1/PollResponseEvent.d.ts.map +1 -0
  387. package/lib/extensible_events_v1/PollResponseEvent.js +135 -0
  388. package/lib/extensible_events_v1/PollResponseEvent.js.map +1 -0
  389. package/lib/extensible_events_v1/PollStartEvent.d.ts +71 -0
  390. package/lib/extensible_events_v1/PollStartEvent.d.ts.map +1 -0
  391. package/lib/extensible_events_v1/PollStartEvent.js +185 -0
  392. package/lib/extensible_events_v1/PollStartEvent.js.map +1 -0
  393. package/lib/extensible_events_v1/utilities.d.ts +14 -0
  394. package/lib/extensible_events_v1/utilities.d.ts.map +1 -0
  395. package/lib/extensible_events_v1/utilities.js +34 -0
  396. package/lib/extensible_events_v1/utilities.js.map +1 -0
  397. package/lib/feature.d.ts +20 -0
  398. package/lib/feature.d.ts.map +1 -0
  399. package/lib/feature.js +85 -0
  400. package/lib/feature.js.map +1 -0
  401. package/lib/filter-component.d.ts +64 -0
  402. package/lib/filter-component.d.ts.map +1 -0
  403. package/lib/filter-component.js +167 -0
  404. package/lib/filter-component.js.map +1 -0
  405. package/lib/filter.d.ts +97 -0
  406. package/lib/filter.d.ts.map +1 -0
  407. package/lib/filter.js +207 -0
  408. package/lib/filter.js.map +1 -0
  409. package/lib/http-api/errors.d.ts +80 -0
  410. package/lib/http-api/errors.d.ts.map +1 -0
  411. package/lib/http-api/errors.js +185 -0
  412. package/lib/http-api/errors.js.map +1 -0
  413. package/lib/http-api/fetch.d.ts +114 -0
  414. package/lib/http-api/fetch.d.ts.map +1 -0
  415. package/lib/http-api/fetch.js +346 -0
  416. package/lib/http-api/fetch.js.map +1 -0
  417. package/lib/http-api/index.d.ts +33 -0
  418. package/lib/http-api/index.d.ts.map +1 -0
  419. package/lib/http-api/index.js +180 -0
  420. package/lib/http-api/index.js.map +1 -0
  421. package/lib/http-api/interface.d.ts +142 -0
  422. package/lib/http-api/interface.d.ts.map +1 -0
  423. package/lib/http-api/interface.js +35 -0
  424. package/lib/http-api/interface.js.map +1 -0
  425. package/lib/http-api/method.d.ts +10 -0
  426. package/lib/http-api/method.d.ts.map +1 -0
  427. package/lib/http-api/method.js +27 -0
  428. package/lib/http-api/method.js.map +1 -0
  429. package/lib/http-api/prefix.d.ts +31 -0
  430. package/lib/http-api/prefix.d.ts.map +1 -0
  431. package/lib/http-api/prefix.js +32 -0
  432. package/lib/http-api/prefix.js.map +1 -0
  433. package/lib/http-api/utils.d.ts +37 -0
  434. package/lib/http-api/utils.d.ts.map +1 -0
  435. package/lib/http-api/utils.js +178 -0
  436. package/lib/http-api/utils.js.map +1 -0
  437. package/lib/index.d.ts +4 -0
  438. package/lib/index.d.ts.map +1 -0
  439. package/lib/index.js +24 -0
  440. package/lib/index.js.map +1 -0
  441. package/lib/indexeddb-helpers.d.ts +10 -0
  442. package/lib/indexeddb-helpers.d.ts.map +1 -0
  443. package/lib/indexeddb-helpers.js +51 -0
  444. package/lib/indexeddb-helpers.js.map +1 -0
  445. package/lib/indexeddb-worker.d.ts +7 -0
  446. package/lib/indexeddb-worker.d.ts.map +1 -0
  447. package/lib/indexeddb-worker.js +25 -0
  448. package/lib/indexeddb-worker.js.map +1 -0
  449. package/lib/interactive-auth.d.ts +337 -0
  450. package/lib/interactive-auth.d.ts.map +1 -0
  451. package/lib/interactive-auth.js +557 -0
  452. package/lib/interactive-auth.js.map +1 -0
  453. package/lib/logger.d.ts +81 -0
  454. package/lib/logger.d.ts.map +1 -0
  455. package/lib/logger.js +139 -0
  456. package/lib/logger.js.map +1 -0
  457. package/lib/matrix.d.ts +118 -0
  458. package/lib/matrix.d.ts.map +1 -0
  459. package/lib/matrix.js +146 -0
  460. package/lib/matrix.js.map +1 -0
  461. package/lib/matrixrtc/CallMembership.d.ts +66 -0
  462. package/lib/matrixrtc/CallMembership.d.ts.map +1 -0
  463. package/lib/matrixrtc/CallMembership.js +197 -0
  464. package/lib/matrixrtc/CallMembership.js.map +1 -0
  465. package/lib/matrixrtc/LivekitFocus.d.ts +16 -0
  466. package/lib/matrixrtc/LivekitFocus.d.ts.map +1 -0
  467. package/lib/matrixrtc/LivekitFocus.js +20 -0
  468. package/lib/matrixrtc/LivekitFocus.js.map +1 -0
  469. package/lib/matrixrtc/MatrixRTCSession.d.ts +295 -0
  470. package/lib/matrixrtc/MatrixRTCSession.d.ts.map +1 -0
  471. package/lib/matrixrtc/MatrixRTCSession.js +1043 -0
  472. package/lib/matrixrtc/MatrixRTCSession.js.map +1 -0
  473. package/lib/matrixrtc/MatrixRTCSessionManager.d.ts +40 -0
  474. package/lib/matrixrtc/MatrixRTCSessionManager.d.ts.map +1 -0
  475. package/lib/matrixrtc/MatrixRTCSessionManager.js +146 -0
  476. package/lib/matrixrtc/MatrixRTCSessionManager.js.map +1 -0
  477. package/lib/matrixrtc/focus.d.ts +10 -0
  478. package/lib/matrixrtc/focus.d.ts.map +1 -0
  479. package/lib/matrixrtc/focus.js +1 -0
  480. package/lib/matrixrtc/focus.js.map +1 -0
  481. package/lib/matrixrtc/index.d.ts +7 -0
  482. package/lib/matrixrtc/index.d.ts.map +1 -0
  483. package/lib/matrixrtc/index.js +21 -0
  484. package/lib/matrixrtc/index.js.map +1 -0
  485. package/lib/matrixrtc/types.d.ts +19 -0
  486. package/lib/matrixrtc/types.d.ts.map +1 -0
  487. package/lib/matrixrtc/types.js +1 -0
  488. package/lib/matrixrtc/types.js.map +1 -0
  489. package/lib/models/MSC3089Branch.d.ts +98 -0
  490. package/lib/models/MSC3089Branch.d.ts.map +1 -0
  491. package/lib/models/MSC3089Branch.js +240 -0
  492. package/lib/models/MSC3089Branch.js.map +1 -0
  493. package/lib/models/MSC3089TreeSpace.d.ts +165 -0
  494. package/lib/models/MSC3089TreeSpace.d.ts.map +1 -0
  495. package/lib/models/MSC3089TreeSpace.js +520 -0
  496. package/lib/models/MSC3089TreeSpace.js.map +1 -0
  497. package/lib/models/ToDeviceMessage.d.ts +17 -0
  498. package/lib/models/ToDeviceMessage.d.ts.map +1 -0
  499. package/lib/models/ToDeviceMessage.js +1 -0
  500. package/lib/models/ToDeviceMessage.js.map +1 -0
  501. package/lib/models/beacon.d.ts +53 -0
  502. package/lib/models/beacon.d.ts.map +1 -0
  503. package/lib/models/beacon.js +174 -0
  504. package/lib/models/beacon.js.map +1 -0
  505. package/lib/models/compare-event-ordering.d.ts +24 -0
  506. package/lib/models/compare-event-ordering.d.ts.map +1 -0
  507. package/lib/models/compare-event-ordering.js +120 -0
  508. package/lib/models/compare-event-ordering.js.map +1 -0
  509. package/lib/models/device.d.ts +45 -0
  510. package/lib/models/device.d.ts.map +1 -0
  511. package/lib/models/device.js +77 -0
  512. package/lib/models/device.js.map +1 -0
  513. package/lib/models/event-context.d.ts +62 -0
  514. package/lib/models/event-context.d.ts.map +1 -0
  515. package/lib/models/event-context.js +113 -0
  516. package/lib/models/event-context.js.map +1 -0
  517. package/lib/models/event-status.d.ts +19 -0
  518. package/lib/models/event-status.d.ts.map +1 -0
  519. package/lib/models/event-status.js +30 -0
  520. package/lib/models/event-status.js.map +1 -0
  521. package/lib/models/event-timeline-set.d.ts +312 -0
  522. package/lib/models/event-timeline-set.d.ts.map +1 -0
  523. package/lib/models/event-timeline-set.js +813 -0
  524. package/lib/models/event-timeline-set.js.map +1 -0
  525. package/lib/models/event-timeline.d.ts +219 -0
  526. package/lib/models/event-timeline.d.ts.map +1 -0
  527. package/lib/models/event-timeline.js +455 -0
  528. package/lib/models/event-timeline.js.map +1 -0
  529. package/lib/models/event.d.ts +811 -0
  530. package/lib/models/event.d.ts.map +1 -0
  531. package/lib/models/event.js +1520 -0
  532. package/lib/models/event.js.map +1 -0
  533. package/lib/models/invites-ignorer.d.ts +136 -0
  534. package/lib/models/invites-ignorer.d.ts.map +1 -0
  535. package/lib/models/invites-ignorer.js +382 -0
  536. package/lib/models/invites-ignorer.js.map +1 -0
  537. package/lib/models/poll.d.ts +67 -0
  538. package/lib/models/poll.d.ts.map +1 -0
  539. package/lib/models/poll.js +241 -0
  540. package/lib/models/poll.js.map +1 -0
  541. package/lib/models/profile-keys.d.ts +8 -0
  542. package/lib/models/profile-keys.d.ts.map +1 -0
  543. package/lib/models/profile-keys.js +8 -0
  544. package/lib/models/profile-keys.js.map +1 -0
  545. package/lib/models/read-receipt.d.ts +115 -0
  546. package/lib/models/read-receipt.d.ts.map +1 -0
  547. package/lib/models/read-receipt.js +366 -0
  548. package/lib/models/read-receipt.js.map +1 -0
  549. package/lib/models/related-relations.d.ts +11 -0
  550. package/lib/models/related-relations.d.ts.map +1 -0
  551. package/lib/models/related-relations.js +33 -0
  552. package/lib/models/related-relations.js.map +1 -0
  553. package/lib/models/relations-container.d.ts +44 -0
  554. package/lib/models/relations-container.d.ts.map +1 -0
  555. package/lib/models/relations-container.js +132 -0
  556. package/lib/models/relations-container.js.map +1 -0
  557. package/lib/models/relations.d.ts +114 -0
  558. package/lib/models/relations.d.ts.map +1 -0
  559. package/lib/models/relations.js +354 -0
  560. package/lib/models/relations.js.map +1 -0
  561. package/lib/models/room-member.d.ts +204 -0
  562. package/lib/models/room-member.d.ts.map +1 -0
  563. package/lib/models/room-member.js +360 -0
  564. package/lib/models/room-member.js.map +1 -0
  565. package/lib/models/room-receipts.d.ts +39 -0
  566. package/lib/models/room-receipts.d.ts.map +1 -0
  567. package/lib/models/room-receipts.js +392 -0
  568. package/lib/models/room-receipts.js.map +1 -0
  569. package/lib/models/room-state.d.ts +468 -0
  570. package/lib/models/room-state.d.ts.map +1 -0
  571. package/lib/models/room-state.js +984 -0
  572. package/lib/models/room-state.js.map +1 -0
  573. package/lib/models/room-summary.d.ts +29 -0
  574. package/lib/models/room-summary.d.ts.map +1 -0
  575. package/lib/models/room-summary.js +28 -0
  576. package/lib/models/room-summary.js.map +1 -0
  577. package/lib/models/room.d.ts +1203 -0
  578. package/lib/models/room.d.ts.map +1 -0
  579. package/lib/models/room.js +3336 -0
  580. package/lib/models/room.js.map +1 -0
  581. package/lib/models/search-result.d.ts +20 -0
  582. package/lib/models/search-result.d.ts.map +1 -0
  583. package/lib/models/search-result.js +52 -0
  584. package/lib/models/search-result.js.map +1 -0
  585. package/lib/models/thread.d.ts +246 -0
  586. package/lib/models/thread.d.ts.map +1 -0
  587. package/lib/models/thread.js +861 -0
  588. package/lib/models/thread.js.map +1 -0
  589. package/lib/models/typed-event-emitter.d.ts +157 -0
  590. package/lib/models/typed-event-emitter.d.ts.map +1 -0
  591. package/lib/models/typed-event-emitter.js +227 -0
  592. package/lib/models/typed-event-emitter.js.map +1 -0
  593. package/lib/models/user.d.ts +195 -0
  594. package/lib/models/user.d.ts.map +1 -0
  595. package/lib/models/user.js +218 -0
  596. package/lib/models/user.js.map +1 -0
  597. package/lib/oidc/authorize.d.ts +90 -0
  598. package/lib/oidc/authorize.d.ts.map +1 -0
  599. package/lib/oidc/authorize.js +278 -0
  600. package/lib/oidc/authorize.js.map +1 -0
  601. package/lib/oidc/discovery.d.ts +14 -0
  602. package/lib/oidc/discovery.d.ts.map +1 -0
  603. package/lib/oidc/discovery.js +66 -0
  604. package/lib/oidc/discovery.js.map +1 -0
  605. package/lib/oidc/error.d.ts +18 -0
  606. package/lib/oidc/error.d.ts.map +1 -0
  607. package/lib/oidc/error.js +35 -0
  608. package/lib/oidc/error.js.map +1 -0
  609. package/lib/oidc/index.d.ts +17 -0
  610. package/lib/oidc/index.d.ts.map +1 -0
  611. package/lib/oidc/index.js +29 -0
  612. package/lib/oidc/index.js.map +1 -0
  613. package/lib/oidc/register.d.ts +43 -0
  614. package/lib/oidc/register.d.ts.map +1 -0
  615. package/lib/oidc/register.js +96 -0
  616. package/lib/oidc/register.js.map +1 -0
  617. package/lib/oidc/tokenRefresher.d.ts +69 -0
  618. package/lib/oidc/tokenRefresher.d.ts.map +1 -0
  619. package/lib/oidc/tokenRefresher.js +148 -0
  620. package/lib/oidc/tokenRefresher.js.map +1 -0
  621. package/lib/oidc/validate.d.ts +90 -0
  622. package/lib/oidc/validate.d.ts.map +1 -0
  623. package/lib/oidc/validate.js +194 -0
  624. package/lib/oidc/validate.js.map +1 -0
  625. package/lib/pushprocessor.d.ts +128 -0
  626. package/lib/pushprocessor.d.ts.map +1 -0
  627. package/lib/pushprocessor.js +685 -0
  628. package/lib/pushprocessor.js.map +1 -0
  629. package/lib/randomstring.d.ts +5 -0
  630. package/lib/randomstring.d.ts.map +1 -0
  631. package/lib/randomstring.js +43 -0
  632. package/lib/randomstring.js.map +1 -0
  633. package/lib/realtime-callbacks.d.ts +18 -0
  634. package/lib/realtime-callbacks.d.ts.map +1 -0
  635. package/lib/realtime-callbacks.js +177 -0
  636. package/lib/realtime-callbacks.js.map +1 -0
  637. package/lib/receipt-accumulator.d.ts +51 -0
  638. package/lib/receipt-accumulator.d.ts.map +1 -0
  639. package/lib/receipt-accumulator.js +164 -0
  640. package/lib/receipt-accumulator.js.map +1 -0
  641. package/lib/rendezvous/MSC4108SignInWithQR.d.ts +112 -0
  642. package/lib/rendezvous/MSC4108SignInWithQR.d.ts.map +1 -0
  643. package/lib/rendezvous/MSC4108SignInWithQR.js +392 -0
  644. package/lib/rendezvous/MSC4108SignInWithQR.js.map +1 -0
  645. package/lib/rendezvous/RendezvousChannel.d.ts +27 -0
  646. package/lib/rendezvous/RendezvousChannel.d.ts.map +1 -0
  647. package/lib/rendezvous/RendezvousChannel.js +1 -0
  648. package/lib/rendezvous/RendezvousChannel.js.map +1 -0
  649. package/lib/rendezvous/RendezvousCode.d.ts +9 -0
  650. package/lib/rendezvous/RendezvousCode.d.ts.map +1 -0
  651. package/lib/rendezvous/RendezvousCode.js +1 -0
  652. package/lib/rendezvous/RendezvousCode.js.map +1 -0
  653. package/lib/rendezvous/RendezvousError.d.ts +6 -0
  654. package/lib/rendezvous/RendezvousError.d.ts.map +1 -0
  655. package/lib/rendezvous/RendezvousError.js +23 -0
  656. package/lib/rendezvous/RendezvousError.js.map +1 -0
  657. package/lib/rendezvous/RendezvousFailureReason.d.ts +31 -0
  658. package/lib/rendezvous/RendezvousFailureReason.d.ts.map +1 -0
  659. package/lib/rendezvous/RendezvousFailureReason.js +38 -0
  660. package/lib/rendezvous/RendezvousFailureReason.js.map +1 -0
  661. package/lib/rendezvous/RendezvousIntent.d.ts +5 -0
  662. package/lib/rendezvous/RendezvousIntent.d.ts.map +1 -0
  663. package/lib/rendezvous/RendezvousIntent.js +22 -0
  664. package/lib/rendezvous/RendezvousIntent.js.map +1 -0
  665. package/lib/rendezvous/RendezvousTransport.d.ts +36 -0
  666. package/lib/rendezvous/RendezvousTransport.d.ts.map +1 -0
  667. package/lib/rendezvous/RendezvousTransport.js +1 -0
  668. package/lib/rendezvous/RendezvousTransport.js.map +1 -0
  669. package/lib/rendezvous/channels/MSC4108SecureChannel.d.ts +58 -0
  670. package/lib/rendezvous/channels/MSC4108SecureChannel.d.ts.map +1 -0
  671. package/lib/rendezvous/channels/MSC4108SecureChannel.js +246 -0
  672. package/lib/rendezvous/channels/MSC4108SecureChannel.js.map +1 -0
  673. package/lib/rendezvous/channels/index.d.ts +2 -0
  674. package/lib/rendezvous/channels/index.d.ts.map +1 -0
  675. package/lib/rendezvous/channels/index.js +18 -0
  676. package/lib/rendezvous/channels/index.js.map +1 -0
  677. package/lib/rendezvous/index.d.ts +10 -0
  678. package/lib/rendezvous/index.d.ts.map +1 -0
  679. package/lib/rendezvous/index.js +23 -0
  680. package/lib/rendezvous/index.js.map +1 -0
  681. package/lib/rendezvous/transports/MSC4108RendezvousSession.d.ts +61 -0
  682. package/lib/rendezvous/transports/MSC4108RendezvousSession.d.ts.map +1 -0
  683. package/lib/rendezvous/transports/MSC4108RendezvousSession.js +253 -0
  684. package/lib/rendezvous/transports/MSC4108RendezvousSession.js.map +1 -0
  685. package/lib/rendezvous/transports/index.d.ts +2 -0
  686. package/lib/rendezvous/transports/index.d.ts.map +1 -0
  687. package/lib/rendezvous/transports/index.js +18 -0
  688. package/lib/rendezvous/transports/index.js.map +1 -0
  689. package/lib/room-hierarchy.d.ts +35 -0
  690. package/lib/room-hierarchy.d.ts.map +1 -0
  691. package/lib/room-hierarchy.js +136 -0
  692. package/lib/room-hierarchy.js.map +1 -0
  693. package/lib/rust-crypto/CrossSigningIdentity.d.ts +33 -0
  694. package/lib/rust-crypto/CrossSigningIdentity.d.ts.map +1 -0
  695. package/lib/rust-crypto/CrossSigningIdentity.js +157 -0
  696. package/lib/rust-crypto/CrossSigningIdentity.js.map +1 -0
  697. package/lib/rust-crypto/DehydratedDeviceManager.d.ts +98 -0
  698. package/lib/rust-crypto/DehydratedDeviceManager.d.ts.map +1 -0
  699. package/lib/rust-crypto/DehydratedDeviceManager.js +285 -0
  700. package/lib/rust-crypto/DehydratedDeviceManager.js.map +1 -0
  701. package/lib/rust-crypto/KeyClaimManager.d.ts +33 -0
  702. package/lib/rust-crypto/KeyClaimManager.d.ts.map +1 -0
  703. package/lib/rust-crypto/KeyClaimManager.js +82 -0
  704. package/lib/rust-crypto/KeyClaimManager.js.map +1 -0
  705. package/lib/rust-crypto/OutgoingRequestProcessor.d.ts +43 -0
  706. package/lib/rust-crypto/OutgoingRequestProcessor.d.ts.map +1 -0
  707. package/lib/rust-crypto/OutgoingRequestProcessor.js +195 -0
  708. package/lib/rust-crypto/OutgoingRequestProcessor.js.map +1 -0
  709. package/lib/rust-crypto/OutgoingRequestsManager.d.ts +47 -0
  710. package/lib/rust-crypto/OutgoingRequestsManager.d.ts.map +1 -0
  711. package/lib/rust-crypto/OutgoingRequestsManager.js +148 -0
  712. package/lib/rust-crypto/OutgoingRequestsManager.js.map +1 -0
  713. package/lib/rust-crypto/PerSessionKeyBackupDownloader.d.ts +120 -0
  714. package/lib/rust-crypto/PerSessionKeyBackupDownloader.d.ts.map +1 -0
  715. package/lib/rust-crypto/PerSessionKeyBackupDownloader.js +467 -0
  716. package/lib/rust-crypto/PerSessionKeyBackupDownloader.js.map +1 -0
  717. package/lib/rust-crypto/RoomEncryptor.d.ts +98 -0
  718. package/lib/rust-crypto/RoomEncryptor.d.ts.map +1 -0
  719. package/lib/rust-crypto/RoomEncryptor.js +299 -0
  720. package/lib/rust-crypto/RoomEncryptor.js.map +1 -0
  721. package/lib/rust-crypto/backup.d.ts +254 -0
  722. package/lib/rust-crypto/backup.d.ts.map +1 -0
  723. package/lib/rust-crypto/backup.js +837 -0
  724. package/lib/rust-crypto/backup.js.map +1 -0
  725. package/lib/rust-crypto/constants.d.ts +3 -0
  726. package/lib/rust-crypto/constants.d.ts.map +1 -0
  727. package/lib/rust-crypto/constants.js +19 -0
  728. package/lib/rust-crypto/constants.js.map +1 -0
  729. package/lib/rust-crypto/device-converter.d.ts +28 -0
  730. package/lib/rust-crypto/device-converter.d.ts.map +1 -0
  731. package/lib/rust-crypto/device-converter.js +123 -0
  732. package/lib/rust-crypto/device-converter.js.map +1 -0
  733. package/lib/rust-crypto/index.d.ts +61 -0
  734. package/lib/rust-crypto/index.d.ts.map +1 -0
  735. package/lib/rust-crypto/index.js +152 -0
  736. package/lib/rust-crypto/index.js.map +1 -0
  737. package/lib/rust-crypto/libolm_migration.d.ts +81 -0
  738. package/lib/rust-crypto/libolm_migration.d.ts.map +1 -0
  739. package/lib/rust-crypto/libolm_migration.js +459 -0
  740. package/lib/rust-crypto/libolm_migration.js.map +1 -0
  741. package/lib/rust-crypto/rust-crypto.d.ts +556 -0
  742. package/lib/rust-crypto/rust-crypto.d.ts.map +1 -0
  743. package/lib/rust-crypto/rust-crypto.js +2016 -0
  744. package/lib/rust-crypto/rust-crypto.js.map +1 -0
  745. package/lib/rust-crypto/secret-storage.d.ts +22 -0
  746. package/lib/rust-crypto/secret-storage.d.ts.map +1 -0
  747. package/lib/rust-crypto/secret-storage.js +63 -0
  748. package/lib/rust-crypto/secret-storage.js.map +1 -0
  749. package/lib/rust-crypto/verification.d.ts +319 -0
  750. package/lib/rust-crypto/verification.d.ts.map +1 -0
  751. package/lib/rust-crypto/verification.js +816 -0
  752. package/lib/rust-crypto/verification.js.map +1 -0
  753. package/lib/scheduler.d.ts +132 -0
  754. package/lib/scheduler.d.ts.map +1 -0
  755. package/lib/scheduler.js +259 -0
  756. package/lib/scheduler.js.map +1 -0
  757. package/lib/secret-storage.d.ts +370 -0
  758. package/lib/secret-storage.d.ts.map +1 -0
  759. package/lib/secret-storage.js +466 -0
  760. package/lib/secret-storage.js.map +1 -0
  761. package/lib/serverCapabilities.d.ts +72 -0
  762. package/lib/serverCapabilities.d.ts.map +1 -0
  763. package/lib/serverCapabilities.js +105 -0
  764. package/lib/serverCapabilities.js.map +1 -0
  765. package/lib/service-types.d.ts +5 -0
  766. package/lib/service-types.d.ts.map +1 -0
  767. package/lib/service-types.js +22 -0
  768. package/lib/service-types.js.map +1 -0
  769. package/lib/sliding-sync-sdk.d.ts +107 -0
  770. package/lib/sliding-sync-sdk.d.ts.map +1 -0
  771. package/lib/sliding-sync-sdk.js +903 -0
  772. package/lib/sliding-sync-sdk.js.map +1 -0
  773. package/lib/sliding-sync.d.ts +343 -0
  774. package/lib/sliding-sync.d.ts.map +1 -0
  775. package/lib/sliding-sync.js +817 -0
  776. package/lib/sliding-sync.js.map +1 -0
  777. package/lib/store/index.d.ts +201 -0
  778. package/lib/store/index.d.ts.map +1 -0
  779. package/lib/store/index.js +1 -0
  780. package/lib/store/index.js.map +1 -0
  781. package/lib/store/indexeddb-backend.d.ts +24 -0
  782. package/lib/store/indexeddb-backend.d.ts.map +1 -0
  783. package/lib/store/indexeddb-backend.js +1 -0
  784. package/lib/store/indexeddb-backend.js.map +1 -0
  785. package/lib/store/indexeddb-local-backend.d.ts +129 -0
  786. package/lib/store/indexeddb-local-backend.d.ts.map +1 -0
  787. package/lib/store/indexeddb-local-backend.js +597 -0
  788. package/lib/store/indexeddb-local-backend.js.map +1 -0
  789. package/lib/store/indexeddb-remote-backend.d.ts +79 -0
  790. package/lib/store/indexeddb-remote-backend.d.ts.map +1 -0
  791. package/lib/store/indexeddb-remote-backend.js +210 -0
  792. package/lib/store/indexeddb-remote-backend.js.map +1 -0
  793. package/lib/store/indexeddb-store-worker.d.ts +35 -0
  794. package/lib/store/indexeddb-store-worker.d.ts.map +1 -0
  795. package/lib/store/indexeddb-store-worker.js +146 -0
  796. package/lib/store/indexeddb-store-worker.js.map +1 -0
  797. package/lib/store/indexeddb.d.ts +142 -0
  798. package/lib/store/indexeddb.d.ts.map +1 -0
  799. package/lib/store/indexeddb.js +347 -0
  800. package/lib/store/indexeddb.js.map +1 -0
  801. package/lib/store/local-storage-events-emitter.d.ts +30 -0
  802. package/lib/store/local-storage-events-emitter.d.ts.map +1 -0
  803. package/lib/store/local-storage-events-emitter.js +37 -0
  804. package/lib/store/local-storage-events-emitter.js.map +1 -0
  805. package/lib/store/memory.d.ts +209 -0
  806. package/lib/store/memory.d.ts.map +1 -0
  807. package/lib/store/memory.js +432 -0
  808. package/lib/store/memory.js.map +1 -0
  809. package/lib/store/stub.d.ts +161 -0
  810. package/lib/store/stub.d.ts.map +1 -0
  811. package/lib/store/stub.js +268 -0
  812. package/lib/store/stub.js.map +1 -0
  813. package/lib/sync-accumulator.d.ts +172 -0
  814. package/lib/sync-accumulator.d.ts.map +1 -0
  815. package/lib/sync-accumulator.js +532 -0
  816. package/lib/sync-accumulator.js.map +1 -0
  817. package/lib/sync.d.ts +260 -0
  818. package/lib/sync.d.ts.map +1 -0
  819. package/lib/sync.js +1686 -0
  820. package/lib/sync.js.map +1 -0
  821. package/lib/testing.d.ts +81 -0
  822. package/lib/testing.d.ts.map +1 -0
  823. package/lib/testing.js +162 -0
  824. package/lib/testing.js.map +1 -0
  825. package/lib/thread-utils.d.ts +10 -0
  826. package/lib/thread-utils.d.ts.map +1 -0
  827. package/lib/thread-utils.js +31 -0
  828. package/lib/thread-utils.js.map +1 -0
  829. package/lib/timeline-window.d.ts +168 -0
  830. package/lib/timeline-window.d.ts.map +1 -0
  831. package/lib/timeline-window.js +494 -0
  832. package/lib/timeline-window.js.map +1 -0
  833. package/lib/types.d.ts +33 -0
  834. package/lib/types.d.ts.map +1 -0
  835. package/lib/types.js +33 -0
  836. package/lib/types.js.map +1 -0
  837. package/lib/utils/decryptAESSecretStorageItem.d.ts +12 -0
  838. package/lib/utils/decryptAESSecretStorageItem.d.ts.map +1 -0
  839. package/lib/utils/decryptAESSecretStorageItem.js +50 -0
  840. package/lib/utils/decryptAESSecretStorageItem.js.map +1 -0
  841. package/lib/utils/encryptAESSecretStorageItem.d.ts +16 -0
  842. package/lib/utils/encryptAESSecretStorageItem.d.ts.map +1 -0
  843. package/lib/utils/encryptAESSecretStorageItem.js +68 -0
  844. package/lib/utils/encryptAESSecretStorageItem.js.map +1 -0
  845. package/lib/utils/internal/deriveKeys.d.ts +10 -0
  846. package/lib/utils/internal/deriveKeys.d.ts.map +1 -0
  847. package/lib/utils/internal/deriveKeys.js +60 -0
  848. package/lib/utils/internal/deriveKeys.js.map +1 -0
  849. package/lib/utils.d.ts +267 -0
  850. package/lib/utils.d.ts.map +1 -0
  851. package/lib/utils.js +749 -0
  852. package/lib/utils.js.map +1 -0
  853. package/lib/version-support.d.ts +19 -0
  854. package/lib/version-support.d.ts.map +1 -0
  855. package/lib/version-support.js +37 -0
  856. package/lib/version-support.js.map +1 -0
  857. package/lib/webrtc/audioContext.d.ts +15 -0
  858. package/lib/webrtc/audioContext.d.ts.map +1 -0
  859. package/lib/webrtc/audioContext.js +46 -0
  860. package/lib/webrtc/audioContext.js.map +1 -0
  861. package/lib/webrtc/call.d.ts +560 -0
  862. package/lib/webrtc/call.d.ts.map +1 -0
  863. package/lib/webrtc/call.js +2541 -0
  864. package/lib/webrtc/call.js.map +1 -0
  865. package/lib/webrtc/callEventHandler.d.ts +37 -0
  866. package/lib/webrtc/callEventHandler.d.ts.map +1 -0
  867. package/lib/webrtc/callEventHandler.js +344 -0
  868. package/lib/webrtc/callEventHandler.js.map +1 -0
  869. package/lib/webrtc/callEventTypes.d.ts +73 -0
  870. package/lib/webrtc/callEventTypes.d.ts.map +1 -0
  871. package/lib/webrtc/callEventTypes.js +13 -0
  872. package/lib/webrtc/callEventTypes.js.map +1 -0
  873. package/lib/webrtc/callFeed.d.ts +128 -0
  874. package/lib/webrtc/callFeed.d.ts.map +1 -0
  875. package/lib/webrtc/callFeed.js +289 -0
  876. package/lib/webrtc/callFeed.js.map +1 -0
  877. package/lib/webrtc/groupCall.d.ts +323 -0
  878. package/lib/webrtc/groupCall.d.ts.map +1 -0
  879. package/lib/webrtc/groupCall.js +1337 -0
  880. package/lib/webrtc/groupCall.js.map +1 -0
  881. package/lib/webrtc/groupCallEventHandler.d.ts +31 -0
  882. package/lib/webrtc/groupCallEventHandler.d.ts.map +1 -0
  883. package/lib/webrtc/groupCallEventHandler.js +178 -0
  884. package/lib/webrtc/groupCallEventHandler.js.map +1 -0
  885. package/lib/webrtc/mediaHandler.d.ts +89 -0
  886. package/lib/webrtc/mediaHandler.d.ts.map +1 -0
  887. package/lib/webrtc/mediaHandler.js +437 -0
  888. package/lib/webrtc/mediaHandler.js.map +1 -0
  889. package/lib/webrtc/stats/callFeedStatsReporter.d.ts +8 -0
  890. package/lib/webrtc/stats/callFeedStatsReporter.d.ts.map +1 -0
  891. package/lib/webrtc/stats/callFeedStatsReporter.js +82 -0
  892. package/lib/webrtc/stats/callFeedStatsReporter.js.map +1 -0
  893. package/lib/webrtc/stats/callStatsReportGatherer.d.ts +25 -0
  894. package/lib/webrtc/stats/callStatsReportGatherer.d.ts.map +1 -0
  895. package/lib/webrtc/stats/callStatsReportGatherer.js +199 -0
  896. package/lib/webrtc/stats/callStatsReportGatherer.js.map +1 -0
  897. package/lib/webrtc/stats/callStatsReportSummary.d.ts +17 -0
  898. package/lib/webrtc/stats/callStatsReportSummary.d.ts.map +1 -0
  899. package/lib/webrtc/stats/callStatsReportSummary.js +1 -0
  900. package/lib/webrtc/stats/callStatsReportSummary.js.map +1 -0
  901. package/lib/webrtc/stats/connectionStats.d.ts +28 -0
  902. package/lib/webrtc/stats/connectionStats.d.ts.map +1 -0
  903. package/lib/webrtc/stats/connectionStats.js +26 -0
  904. package/lib/webrtc/stats/connectionStats.js.map +1 -0
  905. package/lib/webrtc/stats/connectionStatsBuilder.d.ts +5 -0
  906. package/lib/webrtc/stats/connectionStatsBuilder.d.ts.map +1 -0
  907. package/lib/webrtc/stats/connectionStatsBuilder.js +27 -0
  908. package/lib/webrtc/stats/connectionStatsBuilder.js.map +1 -0
  909. package/lib/webrtc/stats/connectionStatsReportBuilder.d.ts +7 -0
  910. package/lib/webrtc/stats/connectionStatsReportBuilder.d.ts.map +1 -0
  911. package/lib/webrtc/stats/connectionStatsReportBuilder.js +121 -0
  912. package/lib/webrtc/stats/connectionStatsReportBuilder.js.map +1 -0
  913. package/lib/webrtc/stats/groupCallStats.d.ts +22 -0
  914. package/lib/webrtc/stats/groupCallStats.d.ts.map +1 -0
  915. package/lib/webrtc/stats/groupCallStats.js +78 -0
  916. package/lib/webrtc/stats/groupCallStats.js.map +1 -0
  917. package/lib/webrtc/stats/media/mediaSsrcHandler.d.ts +10 -0
  918. package/lib/webrtc/stats/media/mediaSsrcHandler.d.ts.map +1 -0
  919. package/lib/webrtc/stats/media/mediaSsrcHandler.js +57 -0
  920. package/lib/webrtc/stats/media/mediaSsrcHandler.js.map +1 -0
  921. package/lib/webrtc/stats/media/mediaTrackHandler.d.ts +12 -0
  922. package/lib/webrtc/stats/media/mediaTrackHandler.d.ts.map +1 -0
  923. package/lib/webrtc/stats/media/mediaTrackHandler.js +62 -0
  924. package/lib/webrtc/stats/media/mediaTrackHandler.js.map +1 -0
  925. package/lib/webrtc/stats/media/mediaTrackStats.d.ts +86 -0
  926. package/lib/webrtc/stats/media/mediaTrackStats.d.ts.map +1 -0
  927. package/lib/webrtc/stats/media/mediaTrackStats.js +142 -0
  928. package/lib/webrtc/stats/media/mediaTrackStats.js.map +1 -0
  929. package/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts +22 -0
  930. package/lib/webrtc/stats/media/mediaTrackStatsHandler.d.ts.map +1 -0
  931. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js +76 -0
  932. package/lib/webrtc/stats/media/mediaTrackStatsHandler.js.map +1 -0
  933. package/lib/webrtc/stats/statsReport.d.ts +99 -0
  934. package/lib/webrtc/stats/statsReport.d.ts.map +1 -0
  935. package/lib/webrtc/stats/statsReport.js +32 -0
  936. package/lib/webrtc/stats/statsReport.js.map +1 -0
  937. package/lib/webrtc/stats/statsReportEmitter.d.ts +15 -0
  938. package/lib/webrtc/stats/statsReportEmitter.d.ts.map +1 -0
  939. package/lib/webrtc/stats/statsReportEmitter.js +33 -0
  940. package/lib/webrtc/stats/statsReportEmitter.js.map +1 -0
  941. package/lib/webrtc/stats/summaryStatsReportGatherer.d.ts +16 -0
  942. package/lib/webrtc/stats/summaryStatsReportGatherer.d.ts.map +1 -0
  943. package/lib/webrtc/stats/summaryStatsReportGatherer.js +116 -0
  944. package/lib/webrtc/stats/summaryStatsReportGatherer.js.map +1 -0
  945. package/lib/webrtc/stats/trackStatsBuilder.d.ts +19 -0
  946. package/lib/webrtc/stats/trackStatsBuilder.d.ts.map +1 -0
  947. package/lib/webrtc/stats/trackStatsBuilder.js +168 -0
  948. package/lib/webrtc/stats/trackStatsBuilder.js.map +1 -0
  949. package/lib/webrtc/stats/transportStats.d.ts +11 -0
  950. package/lib/webrtc/stats/transportStats.d.ts.map +1 -0
  951. package/lib/webrtc/stats/transportStats.js +1 -0
  952. package/lib/webrtc/stats/transportStats.js.map +1 -0
  953. package/lib/webrtc/stats/transportStatsBuilder.d.ts +5 -0
  954. package/lib/webrtc/stats/transportStatsBuilder.d.ts.map +1 -0
  955. package/lib/webrtc/stats/transportStatsBuilder.js +34 -0
  956. package/lib/webrtc/stats/transportStatsBuilder.js.map +1 -0
  957. package/lib/webrtc/stats/valueFormatter.d.ts +4 -0
  958. package/lib/webrtc/stats/valueFormatter.d.ts.map +1 -0
  959. package/lib/webrtc/stats/valueFormatter.js +25 -0
  960. package/lib/webrtc/stats/valueFormatter.js.map +1 -0
  961. package/package.json +134 -0
  962. package/src/@types/AESEncryptedSecretStoragePayload.ts +29 -0
  963. package/src/@types/IIdentityServerProvider.ts +24 -0
  964. package/src/@types/PushRules.ts +209 -0
  965. package/src/@types/another-json.d.ts +19 -0
  966. package/src/@types/auth.ts +252 -0
  967. package/src/@types/beacon.ts +140 -0
  968. package/src/@types/common.ts +22 -0
  969. package/src/@types/crypto.ts +73 -0
  970. package/src/@types/event.ts +370 -0
  971. package/src/@types/events.ts +119 -0
  972. package/src/@types/extensible_events.ts +150 -0
  973. package/src/@types/global.d.ts +70 -0
  974. package/src/@types/local_notifications.ts +19 -0
  975. package/src/@types/location.ts +92 -0
  976. package/src/@types/matrix-sdk-crypto-wasm.d.ts +44 -0
  977. package/src/@types/media.ts +245 -0
  978. package/src/@types/membership.ts +57 -0
  979. package/src/@types/oidc-client-ts.d.ts +24 -0
  980. package/src/@types/partials.ts +67 -0
  981. package/src/@types/polls.ts +119 -0
  982. package/src/@types/read_receipts.ts +61 -0
  983. package/src/@types/registration.ts +102 -0
  984. package/src/@types/requests.ts +314 -0
  985. package/src/@types/search.ts +119 -0
  986. package/src/@types/signed.ts +25 -0
  987. package/src/@types/spaces.ts +37 -0
  988. package/src/@types/state_events.ts +147 -0
  989. package/src/@types/synapse.ts +40 -0
  990. package/src/@types/sync.ts +27 -0
  991. package/src/@types/threepids.ts +29 -0
  992. package/src/@types/topic.ts +63 -0
  993. package/src/@types/uia.ts +29 -0
  994. package/src/NamespacedValue.ts +123 -0
  995. package/src/ReEmitter.ts +93 -0
  996. package/src/ToDeviceMessageQueue.ts +153 -0
  997. package/src/autodiscovery.ts +505 -0
  998. package/src/base64.ts +88 -0
  999. package/src/browser-index.ts +44 -0
  1000. package/src/client.ts +10474 -0
  1001. package/src/common-crypto/CryptoBackend.ts +302 -0
  1002. package/src/common-crypto/README.md +4 -0
  1003. package/src/common-crypto/key-passphrase.ts +43 -0
  1004. package/src/content-helpers.ts +288 -0
  1005. package/src/content-repo.ts +117 -0
  1006. package/src/crypto/CrossSigning.ts +773 -0
  1007. package/src/crypto/DeviceList.ts +989 -0
  1008. package/src/crypto/EncryptionSetup.ts +351 -0
  1009. package/src/crypto/OlmDevice.ts +1500 -0
  1010. package/src/crypto/OutgoingRoomKeyRequestManager.ts +485 -0
  1011. package/src/crypto/RoomList.ts +70 -0
  1012. package/src/crypto/SecretSharing.ts +240 -0
  1013. package/src/crypto/SecretStorage.ts +136 -0
  1014. package/src/crypto/aes.ts +23 -0
  1015. package/src/crypto/algorithms/base.ts +236 -0
  1016. package/src/crypto/algorithms/index.ts +20 -0
  1017. package/src/crypto/algorithms/megolm.ts +2216 -0
  1018. package/src/crypto/algorithms/olm.ts +381 -0
  1019. package/src/crypto/api.ts +70 -0
  1020. package/src/crypto/backup.ts +922 -0
  1021. package/src/crypto/crypto.ts +18 -0
  1022. package/src/crypto/dehydration.ts +272 -0
  1023. package/src/crypto/device-converter.ts +45 -0
  1024. package/src/crypto/deviceinfo.ts +158 -0
  1025. package/src/crypto/index.ts +4414 -0
  1026. package/src/crypto/key_passphrase.ts +42 -0
  1027. package/src/crypto/keybackup.ts +47 -0
  1028. package/src/crypto/olmlib.ts +539 -0
  1029. package/src/crypto/recoverykey.ts +18 -0
  1030. package/src/crypto/store/base.ts +348 -0
  1031. package/src/crypto/store/indexeddb-crypto-store-backend.ts +1250 -0
  1032. package/src/crypto/store/indexeddb-crypto-store.ts +845 -0
  1033. package/src/crypto/store/localStorage-crypto-store.ts +579 -0
  1034. package/src/crypto/store/memory-crypto-store.ts +680 -0
  1035. package/src/crypto/verification/Base.ts +409 -0
  1036. package/src/crypto/verification/Error.ts +76 -0
  1037. package/src/crypto/verification/IllegalMethod.ts +50 -0
  1038. package/src/crypto/verification/QRCode.ts +310 -0
  1039. package/src/crypto/verification/SAS.ts +494 -0
  1040. package/src/crypto/verification/SASDecimal.ts +37 -0
  1041. package/src/crypto/verification/request/Channel.ts +34 -0
  1042. package/src/crypto/verification/request/InRoomChannel.ts +371 -0
  1043. package/src/crypto/verification/request/ToDeviceChannel.ts +354 -0
  1044. package/src/crypto/verification/request/VerificationRequest.ts +976 -0
  1045. package/src/crypto-api/CryptoEvent.ts +93 -0
  1046. package/src/crypto-api/CryptoEventHandlerMap.ts +32 -0
  1047. package/src/crypto-api/index.ts +1175 -0
  1048. package/src/crypto-api/key-passphrase.ts +58 -0
  1049. package/src/crypto-api/keybackup.ts +115 -0
  1050. package/src/crypto-api/recovery-key.ts +69 -0
  1051. package/src/crypto-api/verification.ts +408 -0
  1052. package/src/digest.ts +34 -0
  1053. package/src/embedded.ts +631 -0
  1054. package/src/errors.ts +54 -0
  1055. package/src/event-mapper.ts +97 -0
  1056. package/src/extensible_events_v1/ExtensibleEvent.ts +58 -0
  1057. package/src/extensible_events_v1/InvalidEventError.ts +24 -0
  1058. package/src/extensible_events_v1/MessageEvent.ts +145 -0
  1059. package/src/extensible_events_v1/PollEndEvent.ts +97 -0
  1060. package/src/extensible_events_v1/PollResponseEvent.ts +148 -0
  1061. package/src/extensible_events_v1/PollStartEvent.ts +207 -0
  1062. package/src/extensible_events_v1/utilities.ts +35 -0
  1063. package/src/feature.ts +87 -0
  1064. package/src/filter-component.ts +207 -0
  1065. package/src/filter.ts +245 -0
  1066. package/src/http-api/errors.ts +199 -0
  1067. package/src/http-api/fetch.ts +383 -0
  1068. package/src/http-api/index.ts +191 -0
  1069. package/src/http-api/interface.ts +178 -0
  1070. package/src/http-api/method.ts +25 -0
  1071. package/src/http-api/prefix.ts +48 -0
  1072. package/src/http-api/utils.ts +200 -0
  1073. package/src/index.ts +25 -0
  1074. package/src/indexeddb-helpers.ts +50 -0
  1075. package/src/indexeddb-worker.ts +24 -0
  1076. package/src/interactive-auth.ts +694 -0
  1077. package/src/logger.ts +185 -0
  1078. package/src/matrix.ts +177 -0
  1079. package/src/matrixrtc/CallMembership.ts +247 -0
  1080. package/src/matrixrtc/LivekitFocus.ts +39 -0
  1081. package/src/matrixrtc/MatrixRTCSession.ts +1319 -0
  1082. package/src/matrixrtc/MatrixRTCSessionManager.ts +166 -0
  1083. package/src/matrixrtc/focus.ts +25 -0
  1084. package/src/matrixrtc/index.ts +22 -0
  1085. package/src/matrixrtc/types.ts +36 -0
  1086. package/src/models/MSC3089Branch.ts +272 -0
  1087. package/src/models/MSC3089TreeSpace.ts +565 -0
  1088. package/src/models/ToDeviceMessage.ts +38 -0
  1089. package/src/models/beacon.ts +214 -0
  1090. package/src/models/compare-event-ordering.ts +139 -0
  1091. package/src/models/device.ts +85 -0
  1092. package/src/models/event-context.ts +110 -0
  1093. package/src/models/event-status.ts +39 -0
  1094. package/src/models/event-timeline-set.ts +979 -0
  1095. package/src/models/event-timeline.ts +476 -0
  1096. package/src/models/event.ts +1751 -0
  1097. package/src/models/invites-ignorer.ts +376 -0
  1098. package/src/models/poll.ts +285 -0
  1099. package/src/models/profile-keys.ts +7 -0
  1100. package/src/models/read-receipt.ts +422 -0
  1101. package/src/models/related-relations.ts +39 -0
  1102. package/src/models/relations-container.ts +149 -0
  1103. package/src/models/relations.ts +368 -0
  1104. package/src/models/room-member.ts +457 -0
  1105. package/src/models/room-receipts.ts +439 -0
  1106. package/src/models/room-state.ts +1130 -0
  1107. package/src/models/room-summary.ts +47 -0
  1108. package/src/models/room.ts +3822 -0
  1109. package/src/models/search-result.ts +57 -0
  1110. package/src/models/thread.ts +923 -0
  1111. package/src/models/typed-event-emitter.ts +246 -0
  1112. package/src/models/user.ts +302 -0
  1113. package/src/oidc/authorize.ts +274 -0
  1114. package/src/oidc/discovery.ts +60 -0
  1115. package/src/oidc/error.ts +33 -0
  1116. package/src/oidc/index.ts +34 -0
  1117. package/src/oidc/register.ts +123 -0
  1118. package/src/oidc/tokenRefresher.ts +149 -0
  1119. package/src/oidc/validate.ts +282 -0
  1120. package/src/pushprocessor.ts +837 -0
  1121. package/src/randomstring.ts +51 -0
  1122. package/src/realtime-callbacks.ts +191 -0
  1123. package/src/receipt-accumulator.ts +189 -0
  1124. package/src/rendezvous/MSC4108SignInWithQR.ts +444 -0
  1125. package/src/rendezvous/RendezvousChannel.ts +48 -0
  1126. package/src/rendezvous/RendezvousCode.ts +25 -0
  1127. package/src/rendezvous/RendezvousError.ts +26 -0
  1128. package/src/rendezvous/RendezvousFailureReason.ts +49 -0
  1129. package/src/rendezvous/RendezvousIntent.ts +20 -0
  1130. package/src/rendezvous/RendezvousTransport.ts +58 -0
  1131. package/src/rendezvous/channels/MSC4108SecureChannel.ts +270 -0
  1132. package/src/rendezvous/channels/index.ts +17 -0
  1133. package/src/rendezvous/index.ts +25 -0
  1134. package/src/rendezvous/transports/MSC4108RendezvousSession.ts +270 -0
  1135. package/src/rendezvous/transports/index.ts +17 -0
  1136. package/src/room-hierarchy.ts +152 -0
  1137. package/src/rust-crypto/CrossSigningIdentity.ts +183 -0
  1138. package/src/rust-crypto/DehydratedDeviceManager.ts +306 -0
  1139. package/src/rust-crypto/KeyClaimManager.ts +86 -0
  1140. package/src/rust-crypto/OutgoingRequestProcessor.ts +236 -0
  1141. package/src/rust-crypto/OutgoingRequestsManager.ts +143 -0
  1142. package/src/rust-crypto/PerSessionKeyBackupDownloader.ts +501 -0
  1143. package/src/rust-crypto/RoomEncryptor.ts +352 -0
  1144. package/src/rust-crypto/backup.ts +881 -0
  1145. package/src/rust-crypto/constants.ts +18 -0
  1146. package/src/rust-crypto/device-converter.ts +128 -0
  1147. package/src/rust-crypto/index.ts +237 -0
  1148. package/src/rust-crypto/libolm_migration.ts +530 -0
  1149. package/src/rust-crypto/rust-crypto.ts +2205 -0
  1150. package/src/rust-crypto/secret-storage.ts +60 -0
  1151. package/src/rust-crypto/verification.ts +830 -0
  1152. package/src/scheduler.ts +309 -0
  1153. package/src/secret-storage.ts +693 -0
  1154. package/src/serverCapabilities.ts +139 -0
  1155. package/src/service-types.ts +20 -0
  1156. package/src/sliding-sync-sdk.ts +1026 -0
  1157. package/src/sliding-sync.ts +965 -0
  1158. package/src/store/index.ts +261 -0
  1159. package/src/store/indexeddb-backend.ts +41 -0
  1160. package/src/store/indexeddb-local-backend.ts +610 -0
  1161. package/src/store/indexeddb-remote-backend.ts +213 -0
  1162. package/src/store/indexeddb-store-worker.ts +157 -0
  1163. package/src/store/indexeddb.ts +397 -0
  1164. package/src/store/local-storage-events-emitter.ts +46 -0
  1165. package/src/store/memory.ts +448 -0
  1166. package/src/store/stub.ts +280 -0
  1167. package/src/sync-accumulator.ts +689 -0
  1168. package/src/sync.ts +1920 -0
  1169. package/src/testing.ts +191 -0
  1170. package/src/thread-utils.ts +31 -0
  1171. package/src/timeline-window.ts +536 -0
  1172. package/src/types.ts +59 -0
  1173. package/src/utils/decryptAESSecretStorageItem.ts +54 -0
  1174. package/src/utils/encryptAESSecretStorageItem.ts +73 -0
  1175. package/src/utils/internal/deriveKeys.ts +63 -0
  1176. package/src/utils.ts +763 -0
  1177. package/src/version-support.ts +36 -0
  1178. package/src/webrtc/audioContext.ts +44 -0
  1179. package/src/webrtc/call.ts +3074 -0
  1180. package/src/webrtc/callEventHandler.ts +425 -0
  1181. package/src/webrtc/callEventTypes.ts +93 -0
  1182. package/src/webrtc/callFeed.ts +364 -0
  1183. package/src/webrtc/groupCall.ts +1735 -0
  1184. package/src/webrtc/groupCallEventHandler.ts +234 -0
  1185. package/src/webrtc/mediaHandler.ts +484 -0
  1186. package/src/webrtc/stats/callFeedStatsReporter.ts +94 -0
  1187. package/src/webrtc/stats/callStatsReportGatherer.ts +219 -0
  1188. package/src/webrtc/stats/callStatsReportSummary.ts +30 -0
  1189. package/src/webrtc/stats/connectionStats.ts +47 -0
  1190. package/src/webrtc/stats/connectionStatsBuilder.ts +28 -0
  1191. package/src/webrtc/stats/connectionStatsReportBuilder.ts +140 -0
  1192. package/src/webrtc/stats/groupCallStats.ts +93 -0
  1193. package/src/webrtc/stats/media/mediaSsrcHandler.ts +57 -0
  1194. package/src/webrtc/stats/media/mediaTrackHandler.ts +76 -0
  1195. package/src/webrtc/stats/media/mediaTrackStats.ts +176 -0
  1196. package/src/webrtc/stats/media/mediaTrackStatsHandler.ts +90 -0
  1197. package/src/webrtc/stats/statsReport.ts +133 -0
  1198. package/src/webrtc/stats/statsReportEmitter.ts +49 -0
  1199. package/src/webrtc/stats/summaryStatsReportGatherer.ts +148 -0
  1200. package/src/webrtc/stats/trackStatsBuilder.ts +207 -0
  1201. package/src/webrtc/stats/transportStats.ts +26 -0
  1202. package/src/webrtc/stats/transportStatsBuilder.ts +48 -0
  1203. package/src/webrtc/stats/valueFormatter.ts +27 -0
@@ -0,0 +1,1520 @@
1
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
+ /*
4
+ Copyright 2015 - 2023 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
+ */
18
+
19
+ /**
20
+ * This is an internal module. See {@link MatrixEvent} and {@link RoomEvent} for
21
+ * the public classes.
22
+ */
23
+
24
+ import { ExtensibleEvents } from "matrix-events-sdk";
25
+ import { logger } from "../logger.js";
26
+ import { EVENT_VISIBILITY_CHANGE_TYPE, EventType, RelationType, ToDeviceMessageId, UNSIGNED_THREAD_ID_FIELD, UNSIGNED_MEMBERSHIP_FIELD } from "../@types/event.js";
27
+ import { deepSortedObjectEntries, internaliseString } from "../utils.js";
28
+ import { THREAD_RELATION_TYPE, ThreadEvent } from "./thread.js";
29
+ import { TypedReEmitter } from "../ReEmitter.js";
30
+ import { TypedEventEmitter } from "./typed-event-emitter.js";
31
+ import { DecryptionError } from "../common-crypto/CryptoBackend.js";
32
+ import { EventTimeline } from "./event-timeline.js";
33
+ import { DecryptionFailureCode } from "../crypto-api/index.js";
34
+ export { EventStatus } from "./event-status.js";
35
+
36
+ /* eslint-disable camelcase */
37
+
38
+ /**
39
+ * When an event is a visibility change event, as per MSC3531,
40
+ * the visibility change implied by the event.
41
+ */
42
+
43
+ /* eslint-enable camelcase */
44
+
45
+ /**
46
+ * Message hiding, as specified by https://github.com/matrix-org/matrix-doc/pull/3531.
47
+ */
48
+
49
+ /**
50
+ * Variant of `MessageVisibility` for the case in which the message should be displayed.
51
+ */
52
+
53
+ /**
54
+ * Variant of `MessageVisibility` for the case in which the message should be hidden.
55
+ */
56
+
57
+ // A singleton implementing `IMessageVisibilityVisible`.
58
+ var MESSAGE_VISIBLE = Object.freeze({
59
+ visible: true
60
+ });
61
+ export var MatrixEventEvent = /*#__PURE__*/function (MatrixEventEvent) {
62
+ MatrixEventEvent["Decrypted"] = "Event.decrypted";
63
+ MatrixEventEvent["BeforeRedaction"] = "Event.beforeRedaction";
64
+ MatrixEventEvent["VisibilityChange"] = "Event.visibilityChange";
65
+ MatrixEventEvent["LocalEventIdReplaced"] = "Event.localEventIdReplaced";
66
+ MatrixEventEvent["Status"] = "Event.status";
67
+ MatrixEventEvent["Replaced"] = "Event.replaced";
68
+ MatrixEventEvent["RelationsCreated"] = "Event.relationsCreated";
69
+ return MatrixEventEvent;
70
+ }({});
71
+ export class MatrixEvent extends TypedEventEmitter {
72
+ /**
73
+ * Construct a Matrix Event object
74
+ *
75
+ * @param event - The raw (possibly encrypted) event. <b>Do not access
76
+ * this property</b> directly unless you absolutely have to. Prefer the getter
77
+ * methods defined on this class. Using the getter methods shields your app
78
+ * from changes to event JSON between Matrix versions.
79
+ */
80
+ constructor() {
81
+ var _this$getTs;
82
+ var event = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
83
+ super();
84
+
85
+ // intern the values of matrix events to force share strings and reduce the
86
+ // amount of needless string duplication. This can save moderate amounts of
87
+ // memory (~10% on a 350MB heap).
88
+ // 'membership' at the event level (rather than the content level) is a legacy
89
+ // field that Element never otherwise looks at, but it will still take up a lot
90
+ // of space if we don't intern it.
91
+ this.event = event;
92
+ // applied push rule and action for this event
93
+ _defineProperty(this, "pushDetails", {});
94
+ _defineProperty(this, "_replacingEvent", null);
95
+ _defineProperty(this, "_localRedactionEvent", null);
96
+ _defineProperty(this, "_isCancelled", false);
97
+ _defineProperty(this, "clearEvent", void 0);
98
+ /* Message hiding, as specified by https://github.com/matrix-org/matrix-doc/pull/3531.
99
+ Note: We're returning this object, so any value stored here MUST be frozen.
100
+ */
101
+ _defineProperty(this, "visibility", MESSAGE_VISIBLE);
102
+ // Not all events will be extensible-event compatible, so cache a flag in
103
+ // addition to a falsy cached event value. We check the flag later on in
104
+ // a public getter to decide if the cache is valid.
105
+ _defineProperty(this, "_hasCachedExtEv", false);
106
+ _defineProperty(this, "_cachedExtEv", undefined);
107
+ /** If we failed to decrypt this event, the reason for the failure. Otherwise, `null`. */
108
+ _defineProperty(this, "_decryptionFailureReason", null);
109
+ /* curve25519 key which we believe belongs to the sender of the event. See
110
+ * getSenderKey()
111
+ */
112
+ _defineProperty(this, "senderCurve25519Key", null);
113
+ /* ed25519 key which the sender of this event (for olm) or the creator of
114
+ * the megolm session (for megolm) claims to own. See getClaimedEd25519Key()
115
+ */
116
+ _defineProperty(this, "claimedEd25519Key", null);
117
+ /* curve25519 keys of devices involved in telling us about the
118
+ * senderCurve25519Key and claimedEd25519Key.
119
+ * See getForwardingCurve25519KeyChain().
120
+ */
121
+ _defineProperty(this, "forwardingCurve25519KeyChain", []);
122
+ /* where the decryption key is untrusted
123
+ */
124
+ _defineProperty(this, "untrusted", null);
125
+ /* if we have a process decrypting this event, a Promise which resolves
126
+ * when it is finished. Normally null.
127
+ */
128
+ _defineProperty(this, "decryptionPromise", null);
129
+ /* flag to indicate if we should retry decrypting this event after the
130
+ * first attempt (eg, we have received new data which means that a second
131
+ * attempt may succeed)
132
+ */
133
+ _defineProperty(this, "retryDecryption", false);
134
+ /* The txnId with which this event was sent if it was during this session,
135
+ * allows for a unique ID which does not change when the event comes back down sync.
136
+ */
137
+ _defineProperty(this, "txnId", void 0);
138
+ /**
139
+ * A reference to the thread this event belongs to
140
+ */
141
+ _defineProperty(this, "thread", void 0);
142
+ _defineProperty(this, "threadId", void 0);
143
+ /* Set an approximate timestamp for the event relative the local clock.
144
+ * This will inherently be approximate because it doesn't take into account
145
+ * the time between the server putting the 'age' field on the event as it sent
146
+ * it to us and the time we're now constructing this event, but that's better
147
+ * than assuming the local clock is in sync with the origin HS's clock.
148
+ */
149
+ _defineProperty(this, "localTimestamp", void 0);
150
+ /**
151
+ * The room member who sent this event, or null e.g.
152
+ * this is a presence event. This is only guaranteed to be set for events that
153
+ * appear in a timeline, ie. do not guarantee that it will be set on state
154
+ * events.
155
+ * @privateRemarks
156
+ * Should be read-only
157
+ */
158
+ _defineProperty(this, "sender", null);
159
+ /**
160
+ * The room member who is the target of this event, e.g.
161
+ * the invitee, the person being banned, etc.
162
+ * @privateRemarks
163
+ * Should be read-only
164
+ */
165
+ _defineProperty(this, "target", null);
166
+ /**
167
+ * The sending status of the event.
168
+ * @privateRemarks
169
+ * Should be read-only
170
+ */
171
+ _defineProperty(this, "status", null);
172
+ /**
173
+ * most recent error associated with sending the event, if any
174
+ * @privateRemarks
175
+ * Should be read-only. May not be a MatrixError.
176
+ */
177
+ _defineProperty(this, "error", null);
178
+ /**
179
+ * True if this event is 'forward looking', meaning
180
+ * that getDirectionalContent() will return event.content and not event.prev_content.
181
+ * Only state events may be backwards looking
182
+ * Default: true. <strong>This property is experimental and may change.</strong>
183
+ * @privateRemarks
184
+ * Should be read-only
185
+ */
186
+ _defineProperty(this, "forwardLooking", true);
187
+ /* If the event is a `m.key.verification.request` (or to_device `m.key.verification.start`) event,
188
+ * `Crypto` will set this the `VerificationRequest` for the event
189
+ * so it can be easily accessed from the timeline.
190
+ */
191
+ _defineProperty(this, "verificationRequest", void 0);
192
+ _defineProperty(this, "reEmitter", void 0);
193
+ ["state_key", "type", "sender", "room_id", "membership"].forEach(prop => {
194
+ if (typeof event[prop] !== "string") return;
195
+ event[prop] = internaliseString(event[prop]);
196
+ });
197
+ ["membership", "avatar_url", "displayname"].forEach(prop => {
198
+ var _event$content;
199
+ if (typeof ((_event$content = event.content) === null || _event$content === void 0 ? void 0 : _event$content[prop]) !== "string") return;
200
+ event.content[prop] = internaliseString(event.content[prop]);
201
+ });
202
+ ["rel_type"].forEach(prop => {
203
+ var _event$content2;
204
+ if (typeof ((_event$content2 = event.content) === null || _event$content2 === void 0 || (_event$content2 = _event$content2["m.relates_to"]) === null || _event$content2 === void 0 ? void 0 : _event$content2[prop]) !== "string") return;
205
+ event.content["m.relates_to"][prop] = internaliseString(event.content["m.relates_to"][prop]);
206
+ });
207
+ this.txnId = event.txn_id;
208
+ // The localTimestamp is calculated using the age.
209
+ // Some events lack an `age` property, either because they are EDUs such as typing events,
210
+ // or due to server-side bugs such as https://github.com/matrix-org/synapse/issues/8429.
211
+ // The fallback in these cases will be to use the origin_server_ts.
212
+ // For EDUs, the origin_server_ts also is not defined so we use Date.now().
213
+ var age = this.getAge();
214
+ this.localTimestamp = age !== undefined ? Date.now() - age : (_this$getTs = this.getTs()) !== null && _this$getTs !== void 0 ? _this$getTs : Date.now();
215
+ this.reEmitter = new TypedReEmitter(this);
216
+ }
217
+
218
+ /**
219
+ * Unstable getter to try and get an extensible event. Note that this might
220
+ * return a falsy value if the event could not be parsed as an extensible
221
+ * event.
222
+ *
223
+ * @deprecated Use stable functions where possible.
224
+ */
225
+ get unstableExtensibleEvent() {
226
+ if (!this._hasCachedExtEv) {
227
+ this._cachedExtEv = ExtensibleEvents.parse(this.getEffectiveEvent());
228
+ }
229
+ return this._cachedExtEv;
230
+ }
231
+ invalidateExtensibleEvent() {
232
+ // just reset the flag - that'll trick the getter into parsing a new event
233
+ this._hasCachedExtEv = false;
234
+ }
235
+
236
+ /**
237
+ * Gets the event as it would appear if it had been sent unencrypted.
238
+ *
239
+ * If the event is encrypted, we attempt to mock up an event as it would have looked had the sender not encrypted it.
240
+ * If the event is not encrypted, a copy of it is simply returned as-is.
241
+ *
242
+ * @returns A shallow copy of the event, in wire format, as it would have been had it not been encrypted.
243
+ */
244
+ getEffectiveEvent() {
245
+ var content = Object.assign({}, this.getContent()); // clone for mutation
246
+
247
+ if (this.getWireType() === EventType.RoomMessageEncrypted) {
248
+ // Encrypted events sometimes aren't symmetrical on the `content` so we'll copy
249
+ // that over too, but only for missing properties. We don't copy over mismatches
250
+ // between the plain and decrypted copies of `content` because we assume that the
251
+ // app is relying on the decrypted version, so we want to expose that as a source
252
+ // of truth here too.
253
+ for (var [_key, value] of Object.entries(this.getWireContent())) {
254
+ // Skip fields from the encrypted event schema though - we don't want to leak
255
+ // these.
256
+ if (["algorithm", "ciphertext", "device_id", "sender_key", "session_id"].includes(_key)) {
257
+ continue;
258
+ }
259
+ if (content[_key] === undefined) content[_key] = value;
260
+ }
261
+ }
262
+
263
+ // clearEvent doesn't have all the fields, so we'll copy what we can from this.event.
264
+ // We also copy over our "fixed" content key.
265
+ return Object.assign({}, this.event, this.clearEvent, {
266
+ content
267
+ });
268
+ }
269
+
270
+ /**
271
+ * Get the event_id for this event.
272
+ * @returns The event ID, e.g. <code>$143350589368169JsLZx:localhost
273
+ * </code>
274
+ */
275
+ getId() {
276
+ return this.event.event_id;
277
+ }
278
+
279
+ /**
280
+ * Get the user_id for this event.
281
+ * @returns The user ID, e.g. `@alice:matrix.org`
282
+ */
283
+ getSender() {
284
+ return this.event.sender; // v2 / v1
285
+ }
286
+
287
+ /**
288
+ * Get the (decrypted, if necessary) type of event.
289
+ *
290
+ * @returns The event type, e.g. `m.room.message`
291
+ */
292
+ getType() {
293
+ if (this.clearEvent) {
294
+ return this.clearEvent.type;
295
+ }
296
+ return this.event.type;
297
+ }
298
+
299
+ /**
300
+ * Get the (possibly encrypted) type of the event that will be sent to the
301
+ * homeserver.
302
+ *
303
+ * @returns The event type.
304
+ */
305
+ getWireType() {
306
+ return this.event.type;
307
+ }
308
+
309
+ /**
310
+ * Get the room_id for this event. This will return `undefined`
311
+ * for `m.presence` events.
312
+ * @returns The room ID, e.g. <code>!cURbafjkfsMDVwdRDQ:matrix.org
313
+ * </code>
314
+ */
315
+ getRoomId() {
316
+ return this.event.room_id;
317
+ }
318
+
319
+ /**
320
+ * Get the timestamp of this event.
321
+ * @returns The event timestamp, e.g. `1433502692297`
322
+ */
323
+ getTs() {
324
+ return this.event.origin_server_ts;
325
+ }
326
+
327
+ /**
328
+ * Get the timestamp of this event, as a Date object.
329
+ * @returns The event date, e.g. `new Date(1433502692297)`
330
+ */
331
+ getDate() {
332
+ return this.event.origin_server_ts ? new Date(this.event.origin_server_ts) : null;
333
+ }
334
+
335
+ /**
336
+ * Get a string containing details of this event
337
+ *
338
+ * This is intended for logging, to help trace errors. Example output:
339
+ *
340
+ * @example
341
+ * ```
342
+ * id=$HjnOHV646n0SjLDAqFrgIjim7RCpB7cdMXFrekWYAn type=m.room.encrypted
343
+ * sender=@user:example.com room=!room:example.com ts=2022-10-25T17:30:28.404Z
344
+ * ```
345
+ */
346
+ getDetails() {
347
+ var room = this.getRoomId();
348
+ if (room) {
349
+ var _this$getDate;
350
+ // in-room event
351
+ return "id=".concat(this.getId(), " type=").concat(this.getWireType(), " sender=").concat(this.getSender(), " room=").concat(room, " ts=").concat((_this$getDate = this.getDate()) === null || _this$getDate === void 0 ? void 0 : _this$getDate.toISOString());
352
+ } else {
353
+ // to-device event
354
+ var msgid = this.getContent()[ToDeviceMessageId];
355
+ return "msgid=".concat(msgid, " type=").concat(this.getWireType(), " sender=").concat(this.getSender());
356
+ }
357
+ }
358
+
359
+ /**
360
+ * Get the (decrypted, if necessary) event content JSON, even if the event
361
+ * was replaced by another event.
362
+ *
363
+ * @returns The event content JSON, or an empty object.
364
+ */
365
+ getOriginalContent() {
366
+ if (this._localRedactionEvent) {
367
+ return {};
368
+ }
369
+ if (this.clearEvent) {
370
+ return this.clearEvent.content || {};
371
+ }
372
+ return this.event.content || {};
373
+ }
374
+
375
+ /**
376
+ * Get the (decrypted, if necessary) event content JSON,
377
+ * or the content from the replacing event, if any.
378
+ * See `makeReplaced`.
379
+ *
380
+ * @returns The event content JSON, or an empty object.
381
+ */
382
+ getContent() {
383
+ if (this._localRedactionEvent) {
384
+ return {};
385
+ } else if (this._replacingEvent) {
386
+ return this._replacingEvent.getContent()["m.new_content"] || {};
387
+ } else {
388
+ return this.getOriginalContent();
389
+ }
390
+ }
391
+
392
+ /**
393
+ * Get the (possibly encrypted) event content JSON that will be sent to the
394
+ * homeserver.
395
+ *
396
+ * @returns The event content JSON, or an empty object.
397
+ */
398
+ getWireContent() {
399
+ return this.event.content || {};
400
+ }
401
+
402
+ /**
403
+ * Get the event ID of the thread head
404
+ */
405
+ get threadRootId() {
406
+ var _this$getWireContent;
407
+ // don't allow state events to be threaded as per the spec
408
+ if (this.isState()) {
409
+ return undefined;
410
+ }
411
+ var relatesTo = (_this$getWireContent = this.getWireContent()) === null || _this$getWireContent === void 0 ? void 0 : _this$getWireContent["m.relates_to"];
412
+ if ((relatesTo === null || relatesTo === void 0 ? void 0 : relatesTo.rel_type) === THREAD_RELATION_TYPE.name) {
413
+ return relatesTo.event_id;
414
+ }
415
+ if (this.thread) {
416
+ return this.thread.id;
417
+ }
418
+ if (this.threadId !== undefined) {
419
+ return this.threadId;
420
+ }
421
+ var unsigned = this.getUnsigned();
422
+ if (typeof unsigned[UNSIGNED_THREAD_ID_FIELD.name] === "string") {
423
+ return unsigned[UNSIGNED_THREAD_ID_FIELD.name];
424
+ }
425
+ return undefined;
426
+ }
427
+
428
+ /**
429
+ * A helper to check if an event is a thread's head or not
430
+ */
431
+ get isThreadRoot() {
432
+ // don't allow state events to be threaded as per the spec
433
+ if (this.isState()) {
434
+ return false;
435
+ }
436
+ var threadDetails = this.getServerAggregatedRelation(THREAD_RELATION_TYPE.name);
437
+
438
+ // Bundled relationships only returned when the sync response is limited
439
+ // hence us having to check both bundled relation and inspect the thread
440
+ // model
441
+ return !!threadDetails || this.threadRootId === this.getId();
442
+ }
443
+ get replyEventId() {
444
+ var _this$getWireContent$;
445
+ return (_this$getWireContent$ = this.getWireContent()["m.relates_to"]) === null || _this$getWireContent$ === void 0 || (_this$getWireContent$ = _this$getWireContent$["m.in_reply_to"]) === null || _this$getWireContent$ === void 0 ? void 0 : _this$getWireContent$.event_id;
446
+ }
447
+ get relationEventId() {
448
+ var _this$getWireContent2;
449
+ return (_this$getWireContent2 = this.getWireContent()) === null || _this$getWireContent2 === void 0 || (_this$getWireContent2 = _this$getWireContent2["m.relates_to"]) === null || _this$getWireContent2 === void 0 ? void 0 : _this$getWireContent2.event_id;
450
+ }
451
+
452
+ /**
453
+ * Get the previous event content JSON. This will only return something for
454
+ * state events which exist in the timeline.
455
+ * @returns The previous event content JSON, or an empty object.
456
+ */
457
+ getPrevContent() {
458
+ // v2 then v1 then default
459
+ return this.getUnsigned().prev_content || {};
460
+ }
461
+
462
+ /**
463
+ * Get either 'content' or 'prev_content' depending on if this event is
464
+ * 'forward-looking' or not. This can be modified via event.forwardLooking.
465
+ * In practice, this means we get the chronologically earlier content value
466
+ * for this event (this method should surely be called getEarlierContent)
467
+ * <strong>This method is experimental and may change.</strong>
468
+ * @returns event.content if this event is forward-looking, else
469
+ * event.prev_content.
470
+ */
471
+ getDirectionalContent() {
472
+ return this.forwardLooking ? this.getContent() : this.getPrevContent();
473
+ }
474
+
475
+ /**
476
+ * Get the age of this event. This represents the age of the event when the
477
+ * event arrived at the device, and not the age of the event when this
478
+ * function was called.
479
+ * Can only be returned once the server has echo'ed back
480
+ * @returns The age of this event in milliseconds.
481
+ */
482
+ getAge() {
483
+ return this.getUnsigned().age;
484
+ }
485
+
486
+ /**
487
+ * Get the age of the event when this function was called.
488
+ * This is the 'age' field adjusted according to how long this client has
489
+ * had the event.
490
+ * @returns The age of this event in milliseconds.
491
+ */
492
+ getLocalAge() {
493
+ return Date.now() - this.localTimestamp;
494
+ }
495
+
496
+ /**
497
+ * Get the event state_key if it has one. This will return <code>undefined
498
+ * </code> for message events.
499
+ * @returns The event's `state_key`.
500
+ */
501
+ getStateKey() {
502
+ return this.event.state_key;
503
+ }
504
+
505
+ /**
506
+ * Check if this event is a state event.
507
+ * @returns True if this is a state event.
508
+ */
509
+ isState() {
510
+ return this.event.state_key !== undefined;
511
+ }
512
+
513
+ /**
514
+ * Get the user's room membership at the time the event was sent, as reported
515
+ * by the server. This uses MSC4115.
516
+ *
517
+ * @returns The user's room membership, or `undefined` if the server does
518
+ * not report it.
519
+ */
520
+ getMembershipAtEvent() {
521
+ var unsigned = this.getUnsigned();
522
+ return UNSIGNED_MEMBERSHIP_FIELD.findIn(unsigned);
523
+ }
524
+
525
+ /**
526
+ * Replace the content of this event with encrypted versions.
527
+ * (This is used when sending an event; it should not be used by applications).
528
+ *
529
+ * @internal
530
+ *
531
+ * @param cryptoType - type of the encrypted event - typically
532
+ * <tt>"m.room.encrypted"</tt>
533
+ *
534
+ * @param cryptoContent - raw 'content' for the encrypted event.
535
+ *
536
+ * @param senderCurve25519Key - curve25519 key to record for the
537
+ * sender of this event.
538
+ * See {@link MatrixEvent#getSenderKey}.
539
+ *
540
+ * @param claimedEd25519Key - claimed ed25519 key to record for the
541
+ * sender if this event.
542
+ * See {@link MatrixEvent#getClaimedEd25519Key}
543
+ */
544
+ makeEncrypted(cryptoType, cryptoContent, senderCurve25519Key, claimedEd25519Key) {
545
+ // keep the plain-text data for 'view source'
546
+ this.clearEvent = {
547
+ type: this.event.type,
548
+ content: this.event.content
549
+ };
550
+ this.event.type = cryptoType;
551
+ this.event.content = cryptoContent;
552
+ this.senderCurve25519Key = senderCurve25519Key;
553
+ this.claimedEd25519Key = claimedEd25519Key;
554
+ }
555
+
556
+ /**
557
+ * Check if this event is currently being decrypted.
558
+ *
559
+ * @returns True if this event is currently being decrypted, else false.
560
+ */
561
+ isBeingDecrypted() {
562
+ return this.decryptionPromise != null;
563
+ }
564
+ getDecryptionPromise() {
565
+ return this.decryptionPromise;
566
+ }
567
+
568
+ /**
569
+ * Check if this event is an encrypted event which we failed to decrypt
570
+ *
571
+ * (This implies that we might retry decryption at some point in the future)
572
+ *
573
+ * @returns True if this event is an encrypted event which we
574
+ * couldn't decrypt.
575
+ */
576
+ isDecryptionFailure() {
577
+ return this._decryptionFailureReason !== null;
578
+ }
579
+
580
+ /** If we failed to decrypt this event, the reason for the failure. Otherwise, `null`. */
581
+ get decryptionFailureReason() {
582
+ return this._decryptionFailureReason;
583
+ }
584
+
585
+ /**
586
+ * True if this event is an encrypted event which we failed to decrypt, the receiver's device is unverified and
587
+ * the sender has disabled encrypting to unverified devices.
588
+ *
589
+ * @deprecated: Prefer `event.decryptionFailureReason === DecryptionFailureCode.MEGOLM_KEY_WITHHELD_FOR_UNVERIFIED_DEVICE`.
590
+ */
591
+ get isEncryptedDisabledForUnverifiedDevices() {
592
+ return this.decryptionFailureReason === DecryptionFailureCode.MEGOLM_KEY_WITHHELD_FOR_UNVERIFIED_DEVICE;
593
+ }
594
+ shouldAttemptDecryption() {
595
+ if (this.isRedacted()) return false;
596
+ if (this.isBeingDecrypted()) return false;
597
+ if (this.clearEvent) return false;
598
+ if (!this.isEncrypted()) return false;
599
+ return true;
600
+ }
601
+
602
+ /**
603
+ * Start the process of trying to decrypt this event.
604
+ *
605
+ * (This is used within the SDK: it isn't intended for use by applications)
606
+ *
607
+ * @internal
608
+ *
609
+ * @param crypto - crypto module
610
+ *
611
+ * @returns promise which resolves (to undefined) when the decryption
612
+ * attempt is completed.
613
+ */
614
+ attemptDecryption(crypto) {
615
+ var _arguments = arguments,
616
+ _this = this;
617
+ return _asyncToGenerator(function* () {
618
+ var options = _arguments.length > 1 && _arguments[1] !== undefined ? _arguments[1] : {};
619
+ // start with a couple of sanity checks.
620
+ if (!_this.isEncrypted()) {
621
+ throw new Error("Attempt to decrypt event which isn't encrypted");
622
+ }
623
+ var alreadyDecrypted = _this.clearEvent && !_this.isDecryptionFailure();
624
+ var forceRedecrypt = options.forceRedecryptIfUntrusted && _this.isKeySourceUntrusted();
625
+ if (alreadyDecrypted && !forceRedecrypt) {
626
+ // we may want to just ignore this? let's start with rejecting it.
627
+ throw new Error("Attempt to decrypt event which has already been decrypted");
628
+ }
629
+
630
+ // if we already have a decryption attempt in progress, then it may
631
+ // fail because it was using outdated info. We now have reason to
632
+ // succeed where it failed before, but we don't want to have multiple
633
+ // attempts going at the same time, so just set a flag that says we have
634
+ // new info.
635
+ //
636
+ if (_this.decryptionPromise) {
637
+ logger.log("Event ".concat(_this.getId(), " already being decrypted; queueing a retry"));
638
+ _this.retryDecryption = true;
639
+ return _this.decryptionPromise;
640
+ }
641
+ _this.decryptionPromise = _this.decryptionLoop(crypto, options);
642
+ return _this.decryptionPromise;
643
+ })();
644
+ }
645
+
646
+ /**
647
+ * Cancel any room key request for this event and resend another.
648
+ *
649
+ * @param crypto - crypto module
650
+ * @param userId - the user who received this event
651
+ *
652
+ * @returns a promise that resolves when the request is queued
653
+ */
654
+ cancelAndResendKeyRequest(crypto, userId) {
655
+ var wireContent = this.getWireContent();
656
+ return crypto.requestRoomKey({
657
+ algorithm: wireContent.algorithm,
658
+ room_id: this.getRoomId(),
659
+ session_id: wireContent.session_id,
660
+ sender_key: wireContent.sender_key
661
+ }, this.getKeyRequestRecipients(userId), true);
662
+ }
663
+
664
+ /**
665
+ * Calculate the recipients for keyshare requests.
666
+ *
667
+ * @param userId - the user who received this event.
668
+ *
669
+ * @returns array of recipients
670
+ */
671
+ getKeyRequestRecipients(userId) {
672
+ // send the request to all of our own devices
673
+ var recipients = [{
674
+ userId,
675
+ deviceId: "*"
676
+ }];
677
+ return recipients;
678
+ }
679
+ decryptionLoop(crypto) {
680
+ var _arguments2 = arguments,
681
+ _this2 = this;
682
+ return _asyncToGenerator(function* () {
683
+ var options = _arguments2.length > 1 && _arguments2[1] !== undefined ? _arguments2[1] : {};
684
+ // make sure that this method never runs completely synchronously.
685
+ // (doing so would mean that we would clear decryptionPromise *before*
686
+ // it is set in attemptDecryption - and hence end up with a stuck
687
+ // `decryptionPromise`).
688
+ yield Promise.resolve();
689
+
690
+ // eslint-disable-next-line no-constant-condition
691
+ while (true) {
692
+ _this2.retryDecryption = false;
693
+ var err = undefined;
694
+ try {
695
+ var res = yield crypto.decryptEvent(_this2);
696
+ if (options.isRetry === true) {
697
+ logger.info("Decrypted event on retry (".concat(_this2.getDetails(), ")"));
698
+ }
699
+ _this2.setClearData(res);
700
+ _this2._decryptionFailureReason = null;
701
+ } catch (e) {
702
+ var detailedError = e instanceof DecryptionError ? e.detailedString : String(e);
703
+ err = e;
704
+
705
+ // see if we have a retry queued.
706
+ //
707
+ // NB: make sure to keep this check in the same tick of the
708
+ // event loop as `decryptionPromise = null` below - otherwise we
709
+ // risk a race:
710
+ //
711
+ // * A: we check retryDecryption here and see that it is
712
+ // false
713
+ // * B: we get a second call to attemptDecryption, which sees
714
+ // that decryptionPromise is set so sets
715
+ // retryDecryption
716
+ // * A: we continue below, clear decryptionPromise, and
717
+ // never do the retry.
718
+ //
719
+ if (_this2.retryDecryption) {
720
+ // decryption error, but we have a retry queued.
721
+ logger.log("Error decrypting event (".concat(_this2.getDetails(), "), but retrying: ").concat(detailedError));
722
+ continue;
723
+ }
724
+
725
+ // decryption error, no retries queued. Warn about the error and
726
+ // set it to m.bad.encrypted.
727
+ //
728
+ // the detailedString already includes the name and message of the error, and the stack isn't much use,
729
+ // so we don't bother to log `e` separately.
730
+ logger.warn("Error decrypting event (".concat(_this2.getDetails(), "): ").concat(detailedError));
731
+ _this2.setClearDataForDecryptionFailure(String(e));
732
+ _this2._decryptionFailureReason = e instanceof DecryptionError ? e.code : DecryptionFailureCode.UNKNOWN_ERROR;
733
+ }
734
+
735
+ // Make sure we clear 'decryptionPromise' before sending the 'Event.decrypted' event,
736
+ // otherwise the app will be confused to see `isBeingDecrypted` still set when
737
+ // there isn't an `Event.decrypted` on the way.
738
+ //
739
+ // see also notes on retryDecryption above.
740
+ //
741
+ _this2.decryptionPromise = null;
742
+ _this2.retryDecryption = false;
743
+
744
+ // Before we emit the event, clear the push actions so that they can be recalculated
745
+ // by relevant code. We do this because the clear event has now changed, making it
746
+ // so that existing rules can be re-run over the applicable properties. Stuff like
747
+ // highlighting when the user's name is mentioned rely on this happening. We also want
748
+ // to set the push actions before emitting so that any notification listeners don't
749
+ // pick up the wrong contents.
750
+ _this2.setPushDetails();
751
+ if (options.emit !== false) {
752
+ _this2.emit(MatrixEventEvent.Decrypted, _this2, err);
753
+ }
754
+ return;
755
+ }
756
+ })();
757
+ }
758
+
759
+ /**
760
+ * Update the cleartext data on this event.
761
+ *
762
+ * (This is used after decrypting an event; it should not be used by applications).
763
+ *
764
+ * @internal
765
+ *
766
+ * @param decryptionResult - the decryption result, including the plaintext and some key info
767
+ */
768
+ setClearData(decryptionResult) {
769
+ var _decryptionResult$sen, _decryptionResult$cla;
770
+ this.clearEvent = decryptionResult.clearEvent;
771
+ this.senderCurve25519Key = (_decryptionResult$sen = decryptionResult.senderCurve25519Key) !== null && _decryptionResult$sen !== void 0 ? _decryptionResult$sen : null;
772
+ this.claimedEd25519Key = (_decryptionResult$cla = decryptionResult.claimedEd25519Key) !== null && _decryptionResult$cla !== void 0 ? _decryptionResult$cla : null;
773
+ this.forwardingCurve25519KeyChain = decryptionResult.forwardingCurve25519KeyChain || [];
774
+ this.untrusted = decryptionResult.untrusted || false;
775
+ this.invalidateExtensibleEvent();
776
+ }
777
+
778
+ /**
779
+ * Update the cleartext data on this event after a decryption failure.
780
+ *
781
+ * @param reason - the textual reason for the failure
782
+ */
783
+ setClearDataForDecryptionFailure(reason) {
784
+ this.clearEvent = {
785
+ type: EventType.RoomMessage,
786
+ content: {
787
+ msgtype: "m.bad.encrypted",
788
+ body: "** Unable to decrypt: ".concat(reason, " **")
789
+ }
790
+ };
791
+ this.senderCurve25519Key = null;
792
+ this.claimedEd25519Key = null;
793
+ this.forwardingCurve25519KeyChain = [];
794
+ this.untrusted = false;
795
+ this.invalidateExtensibleEvent();
796
+ }
797
+
798
+ /**
799
+ * Gets the cleartext content for this event. If the event is not encrypted,
800
+ * or encryption has not been completed, this will return null.
801
+ *
802
+ * @returns The cleartext (decrypted) content for the event
803
+ */
804
+ getClearContent() {
805
+ return this.clearEvent ? this.clearEvent.content : null;
806
+ }
807
+
808
+ /**
809
+ * Check if the event is encrypted.
810
+ * @returns True if this event is encrypted.
811
+ */
812
+ isEncrypted() {
813
+ return !this.isState() && this.event.type === EventType.RoomMessageEncrypted;
814
+ }
815
+
816
+ /**
817
+ * The curve25519 key for the device that we think sent this event
818
+ *
819
+ * For an Olm-encrypted event, this is inferred directly from the DH
820
+ * exchange at the start of the session: the curve25519 key is involved in
821
+ * the DH exchange, so only a device which holds the private part of that
822
+ * key can establish such a session.
823
+ *
824
+ * For a megolm-encrypted event, it is inferred from the Olm message which
825
+ * established the megolm session
826
+ */
827
+ getSenderKey() {
828
+ return this.senderCurve25519Key;
829
+ }
830
+
831
+ /**
832
+ * The additional keys the sender of this encrypted event claims to possess.
833
+ *
834
+ * Just a wrapper for #getClaimedEd25519Key (q.v.)
835
+ */
836
+ getKeysClaimed() {
837
+ if (!this.claimedEd25519Key) return {};
838
+ return {
839
+ ed25519: this.claimedEd25519Key
840
+ };
841
+ }
842
+
843
+ /**
844
+ * Get the ed25519 the sender of this event claims to own.
845
+ *
846
+ * For Olm messages, this claim is encoded directly in the plaintext of the
847
+ * event itself. For megolm messages, it is implied by the m.room_key event
848
+ * which established the megolm session.
849
+ *
850
+ * Until we download the device list of the sender, it's just a claim: the
851
+ * device list gives a proof that the owner of the curve25519 key used for
852
+ * this event (and returned by #getSenderKey) also owns the ed25519 key by
853
+ * signing the public curve25519 key with the ed25519 key.
854
+ *
855
+ * In general, applications should not use this method directly, but should
856
+ * instead use {@link Crypto.CryptoApi#getEncryptionInfoForEvent}.
857
+ */
858
+ getClaimedEd25519Key() {
859
+ return this.claimedEd25519Key;
860
+ }
861
+
862
+ /**
863
+ * Get the curve25519 keys of the devices which were involved in telling us
864
+ * about the claimedEd25519Key and sender curve25519 key.
865
+ *
866
+ * Normally this will be empty, but in the case of a forwarded megolm
867
+ * session, the sender keys are sent to us by another device (the forwarding
868
+ * device), which we need to trust to do this. In that case, the result will
869
+ * be a list consisting of one entry.
870
+ *
871
+ * If the device that sent us the key (A) got it from another device which
872
+ * it wasn't prepared to vouch for (B), the result will be [A, B]. And so on.
873
+ *
874
+ * @returns base64-encoded curve25519 keys, from oldest to newest.
875
+ */
876
+ getForwardingCurve25519KeyChain() {
877
+ return this.forwardingCurve25519KeyChain;
878
+ }
879
+
880
+ /**
881
+ * Whether the decryption key was obtained from an untrusted source. If so,
882
+ * we cannot verify the authenticity of the message.
883
+ */
884
+ isKeySourceUntrusted() {
885
+ return !!this.untrusted;
886
+ }
887
+ getUnsigned() {
888
+ return this.event.unsigned || {};
889
+ }
890
+ setUnsigned(unsigned) {
891
+ this.event.unsigned = unsigned;
892
+ }
893
+ unmarkLocallyRedacted() {
894
+ var value = this._localRedactionEvent;
895
+ this._localRedactionEvent = null;
896
+ if (this.event.unsigned) {
897
+ this.event.unsigned.redacted_because = undefined;
898
+ }
899
+ return !!value;
900
+ }
901
+ markLocallyRedacted(redactionEvent) {
902
+ if (this._localRedactionEvent) return;
903
+ this.emit(MatrixEventEvent.BeforeRedaction, this, redactionEvent);
904
+ this._localRedactionEvent = redactionEvent;
905
+ if (!this.event.unsigned) {
906
+ this.event.unsigned = {};
907
+ }
908
+ this.event.unsigned.redacted_because = redactionEvent.event;
909
+ }
910
+
911
+ /**
912
+ * Change the visibility of an event, as per https://github.com/matrix-org/matrix-doc/pull/3531 .
913
+ *
914
+ * @param visibilityChange - event holding a hide/unhide payload, or nothing
915
+ * if the event is being reset to its original visibility (presumably
916
+ * by a visibility event being redacted).
917
+ *
918
+ * @remarks
919
+ * Fires {@link MatrixEventEvent.VisibilityChange} if `visibilityEvent`
920
+ * caused a change in the actual visibility of this event, either by making it
921
+ * visible (if it was hidden), by making it hidden (if it was visible) or by
922
+ * changing the reason (if it was hidden).
923
+ */
924
+ applyVisibilityEvent(visibilityChange) {
925
+ var _visibilityChange$vis, _visibilityChange$rea;
926
+ var visible = (_visibilityChange$vis = visibilityChange === null || visibilityChange === void 0 ? void 0 : visibilityChange.visible) !== null && _visibilityChange$vis !== void 0 ? _visibilityChange$vis : true;
927
+ var reason = (_visibilityChange$rea = visibilityChange === null || visibilityChange === void 0 ? void 0 : visibilityChange.reason) !== null && _visibilityChange$rea !== void 0 ? _visibilityChange$rea : null;
928
+ var change = false;
929
+ if (this.visibility.visible !== visible) {
930
+ change = true;
931
+ } else if (!this.visibility.visible && this.visibility["reason"] !== reason) {
932
+ change = true;
933
+ }
934
+ if (change) {
935
+ if (visible) {
936
+ this.visibility = MESSAGE_VISIBLE;
937
+ } else {
938
+ this.visibility = Object.freeze({
939
+ visible: false,
940
+ reason
941
+ });
942
+ }
943
+ this.emit(MatrixEventEvent.VisibilityChange, this, visible);
944
+ }
945
+ }
946
+
947
+ /**
948
+ * Return instructions to display or hide the message.
949
+ *
950
+ * @returns Instructions determining whether the message
951
+ * should be displayed.
952
+ */
953
+ messageVisibility() {
954
+ // Note: We may return `this.visibility` without fear, as
955
+ // this is a shallow frozen object.
956
+ return this.visibility;
957
+ }
958
+
959
+ /**
960
+ * Update the content of an event in the same way it would be by the server
961
+ * if it were redacted before it was sent to us
962
+ *
963
+ * @param redactionEvent - event causing the redaction
964
+ * @param room - the room in which the event exists
965
+ */
966
+ makeRedacted(redactionEvent, room) {
967
+ // quick sanity-check
968
+ if (!redactionEvent.event) {
969
+ throw new Error("invalid redactionEvent in makeRedacted");
970
+ }
971
+ this._localRedactionEvent = null;
972
+ this.emit(MatrixEventEvent.BeforeRedaction, this, redactionEvent);
973
+ this._replacingEvent = null;
974
+ // we attempt to replicate what we would see from the server if
975
+ // the event had been redacted before we saw it.
976
+ //
977
+ // The server removes (most of) the content of the event, and adds a
978
+ // "redacted_because" key to the unsigned section containing the
979
+ // redacted event.
980
+ if (!this.event.unsigned) {
981
+ this.event.unsigned = {};
982
+ }
983
+ this.event.unsigned.redacted_because = redactionEvent.event;
984
+ for (var _key2 in this.event) {
985
+ if (this.event.hasOwnProperty(_key2) && !REDACT_KEEP_KEYS.has(_key2)) {
986
+ delete this.event[_key2];
987
+ }
988
+ }
989
+
990
+ // If the event is encrypted prune the decrypted bits
991
+ if (this.isEncrypted()) {
992
+ this.clearEvent = undefined;
993
+ }
994
+ var keeps = this.getType() in REDACT_KEEP_CONTENT_MAP ? REDACT_KEEP_CONTENT_MAP[this.getType()] : {};
995
+ var content = this.getContent();
996
+ for (var _key3 in content) {
997
+ if (content.hasOwnProperty(_key3) && !keeps[_key3]) {
998
+ delete content[_key3];
999
+ }
1000
+ }
1001
+
1002
+ // If the redacted event was in a thread (but not thread root), move it
1003
+ // to the main timeline. This will change if MSC3389 is merged.
1004
+ if (!this.isThreadRoot && this.threadRootId && this.threadRootId !== this.getId()) {
1005
+ this.moveAllRelatedToMainTimeline(room);
1006
+ redactionEvent.moveToMainTimeline(room);
1007
+ }
1008
+ this.invalidateExtensibleEvent();
1009
+ }
1010
+ moveAllRelatedToMainTimeline(room) {
1011
+ var thread = this.thread;
1012
+ this.moveToMainTimeline(room);
1013
+
1014
+ // If we dont have access to the thread, we can only move this
1015
+ // event, not things related to it.
1016
+ if (thread) {
1017
+ for (var _event of thread.events) {
1018
+ var _event$getRelation;
1019
+ if (((_event$getRelation = _event.getRelation()) === null || _event$getRelation === void 0 ? void 0 : _event$getRelation.event_id) === this.getId()) {
1020
+ _event.moveAllRelatedToMainTimeline(room);
1021
+ }
1022
+ }
1023
+ }
1024
+ }
1025
+ moveToMainTimeline(room) {
1026
+ var _this$thread;
1027
+ // Remove it from its thread
1028
+ (_this$thread = this.thread) === null || _this$thread === void 0 || _this$thread.timelineSet.removeEvent(this.getId());
1029
+ this.setThread(undefined);
1030
+
1031
+ // And insert it into the main timeline
1032
+ var timeline = room.getLiveTimeline();
1033
+ // We use insertEventIntoTimeline to insert it in timestamp order,
1034
+ // because we don't know where it should go (until we have MSC4033).
1035
+ timeline.getTimelineSet().insertEventIntoTimeline(this, timeline, timeline.getState(EventTimeline.FORWARDS));
1036
+ }
1037
+
1038
+ /**
1039
+ * Check if this event has been redacted
1040
+ *
1041
+ * @returns True if this event has been redacted
1042
+ */
1043
+ isRedacted() {
1044
+ return Boolean(this.getUnsigned().redacted_because);
1045
+ }
1046
+
1047
+ /**
1048
+ * Check if this event is a redaction of another event
1049
+ *
1050
+ * @returns True if this event is a redaction
1051
+ */
1052
+ isRedaction() {
1053
+ return this.getType() === EventType.RoomRedaction;
1054
+ }
1055
+
1056
+ /**
1057
+ * Return the visibility change caused by this event,
1058
+ * as per https://github.com/matrix-org/matrix-doc/pull/3531.
1059
+ *
1060
+ * @returns If the event is a well-formed visibility change event,
1061
+ * an instance of `IVisibilityChange`, otherwise `null`.
1062
+ */
1063
+ asVisibilityChange() {
1064
+ if (!EVENT_VISIBILITY_CHANGE_TYPE.matches(this.getType())) {
1065
+ // Not a visibility change event.
1066
+ return null;
1067
+ }
1068
+ var relation = this.getRelation();
1069
+ if (!relation || relation.rel_type != "m.reference") {
1070
+ // Ill-formed, ignore this event.
1071
+ return null;
1072
+ }
1073
+ var eventId = relation.event_id;
1074
+ if (!eventId) {
1075
+ // Ill-formed, ignore this event.
1076
+ return null;
1077
+ }
1078
+ var content = this.getWireContent();
1079
+ var visible = !!content.visible;
1080
+ var reason = content.reason;
1081
+ if (reason && typeof reason != "string") {
1082
+ // Ill-formed, ignore this event.
1083
+ return null;
1084
+ }
1085
+ // Well-formed visibility change event.
1086
+ return {
1087
+ visible,
1088
+ reason,
1089
+ eventId
1090
+ };
1091
+ }
1092
+
1093
+ /**
1094
+ * Check if this event alters the visibility of another event,
1095
+ * as per https://github.com/matrix-org/matrix-doc/pull/3531.
1096
+ *
1097
+ * @returns True if this event alters the visibility
1098
+ * of another event.
1099
+ */
1100
+ isVisibilityEvent() {
1101
+ return EVENT_VISIBILITY_CHANGE_TYPE.matches(this.getType());
1102
+ }
1103
+
1104
+ /**
1105
+ * Get the (decrypted, if necessary) redaction event JSON
1106
+ * if event was redacted
1107
+ *
1108
+ * @returns The redaction event JSON, or an empty object
1109
+ */
1110
+ getRedactionEvent() {
1111
+ var _this$clearEvent, _this$event$unsigned;
1112
+ if (!this.isRedacted()) return null;
1113
+ if ((_this$clearEvent = this.clearEvent) !== null && _this$clearEvent !== void 0 && _this$clearEvent.unsigned) {
1114
+ var _this$clearEvent$unsi, _this$clearEvent2;
1115
+ return (_this$clearEvent$unsi = (_this$clearEvent2 = this.clearEvent) === null || _this$clearEvent2 === void 0 ? void 0 : _this$clearEvent2.unsigned.redacted_because) !== null && _this$clearEvent$unsi !== void 0 ? _this$clearEvent$unsi : null;
1116
+ } else if ((_this$event$unsigned = this.event.unsigned) !== null && _this$event$unsigned !== void 0 && _this$event$unsigned.redacted_because) {
1117
+ return this.event.unsigned.redacted_because;
1118
+ } else {
1119
+ return {};
1120
+ }
1121
+ }
1122
+
1123
+ /**
1124
+ * Get the push actions, if known, for this event
1125
+ *
1126
+ * @returns push actions
1127
+ */
1128
+ getPushActions() {
1129
+ return this.pushDetails.actions || null;
1130
+ }
1131
+
1132
+ /**
1133
+ * Get the push details, if known, for this event
1134
+ *
1135
+ * @returns push actions
1136
+ */
1137
+ getPushDetails() {
1138
+ return this.pushDetails;
1139
+ }
1140
+
1141
+ /**
1142
+ * Set the push details for this event.
1143
+ *
1144
+ * @param pushActions - push actions
1145
+ * @param rule - the executed push rule
1146
+ */
1147
+ setPushDetails(pushActions, rule) {
1148
+ this.pushDetails = {
1149
+ actions: pushActions,
1150
+ rule
1151
+ };
1152
+ }
1153
+
1154
+ /**
1155
+ * Replace the `event` property and recalculate any properties based on it.
1156
+ * @param event - the object to assign to the `event` property
1157
+ */
1158
+ handleRemoteEcho(event) {
1159
+ var oldUnsigned = this.getUnsigned();
1160
+ var oldId = this.getId();
1161
+ this.event = event;
1162
+ // if this event was redacted before it was sent, it's locally marked as redacted.
1163
+ // At this point, we've received the remote echo for the event, but not yet for
1164
+ // the redaction that we are sending ourselves. Preserve the locally redacted
1165
+ // state by copying over redacted_because so we don't get a flash of
1166
+ // redacted, not-redacted, redacted as remote echos come in
1167
+ if (oldUnsigned.redacted_because) {
1168
+ if (!this.event.unsigned) {
1169
+ this.event.unsigned = {};
1170
+ }
1171
+ this.event.unsigned.redacted_because = oldUnsigned.redacted_because;
1172
+ }
1173
+ // successfully sent.
1174
+ this.setStatus(null);
1175
+ if (this.getId() !== oldId) {
1176
+ // emit the event if it changed
1177
+ this.emit(MatrixEventEvent.LocalEventIdReplaced, this);
1178
+ }
1179
+ this.localTimestamp = Date.now() - this.getAge();
1180
+ }
1181
+
1182
+ /**
1183
+ * Whether the event is in any phase of sending, send failure, waiting for
1184
+ * remote echo, etc.
1185
+ */
1186
+ isSending() {
1187
+ return !!this.status;
1188
+ }
1189
+
1190
+ /**
1191
+ * Update the event's sending status and emit an event as well.
1192
+ *
1193
+ * @param status - The new status
1194
+ */
1195
+ setStatus(status) {
1196
+ this.status = status;
1197
+ this.emit(MatrixEventEvent.Status, this, status);
1198
+ }
1199
+ replaceLocalEventId(eventId) {
1200
+ this.event.event_id = eventId;
1201
+ this.emit(MatrixEventEvent.LocalEventIdReplaced, this);
1202
+ }
1203
+
1204
+ /**
1205
+ * Get whether the event is a relation event, and of a given type if
1206
+ * `relType` is passed in. State events cannot be relation events
1207
+ *
1208
+ * @param relType - if given, checks that the relation is of the
1209
+ * given type
1210
+ */
1211
+ isRelation(relType) {
1212
+ var _this$getWireContent3;
1213
+ // Relation info is lifted out of the encrypted content when sent to
1214
+ // encrypted rooms, so we have to check `getWireContent` for this.
1215
+ var relation = (_this$getWireContent3 = this.getWireContent()) === null || _this$getWireContent3 === void 0 ? void 0 : _this$getWireContent3["m.relates_to"];
1216
+ if (this.isState() && !!(relation !== null && relation !== void 0 && relation.rel_type) && [RelationType.Replace, RelationType.Thread].includes(relation.rel_type)) {
1217
+ // State events cannot be m.replace or m.thread relations
1218
+ return false;
1219
+ }
1220
+ return !!(relation !== null && relation !== void 0 && relation.rel_type && relation.event_id && (relType ? relation.rel_type === relType : true));
1221
+ }
1222
+
1223
+ /**
1224
+ * Get relation info for the event, if any.
1225
+ */
1226
+ getRelation() {
1227
+ var _this$getWireContent$2;
1228
+ if (!this.isRelation()) {
1229
+ return null;
1230
+ }
1231
+ return (_this$getWireContent$2 = this.getWireContent()["m.relates_to"]) !== null && _this$getWireContent$2 !== void 0 ? _this$getWireContent$2 : null;
1232
+ }
1233
+
1234
+ /**
1235
+ * Set an event that replaces the content of this event, through an m.replace relation.
1236
+ *
1237
+ * @param newEvent - the event with the replacing content, if any.
1238
+ *
1239
+ * @remarks
1240
+ * Fires {@link MatrixEventEvent.Replaced}
1241
+ */
1242
+ makeReplaced(newEvent) {
1243
+ // don't allow redacted events to be replaced.
1244
+ // if newEvent is null we allow to go through though,
1245
+ // as with local redaction, the replacing event might get
1246
+ // cancelled, which should be reflected on the target event.
1247
+ if (this.isRedacted() && newEvent) {
1248
+ return;
1249
+ }
1250
+ // don't allow state events to be replaced using this mechanism as per MSC2676
1251
+ if (this.isState()) {
1252
+ return;
1253
+ }
1254
+ if (this._replacingEvent !== newEvent) {
1255
+ this._replacingEvent = newEvent !== null && newEvent !== void 0 ? newEvent : null;
1256
+ this.emit(MatrixEventEvent.Replaced, this);
1257
+ this.invalidateExtensibleEvent();
1258
+ }
1259
+ }
1260
+
1261
+ /**
1262
+ * Returns the status of any associated edit or redaction
1263
+ * (not for reactions/annotations as their local echo doesn't affect the original event),
1264
+ * or else the status of the event.
1265
+ */
1266
+ getAssociatedStatus() {
1267
+ if (this._replacingEvent) {
1268
+ return this._replacingEvent.status;
1269
+ } else if (this._localRedactionEvent) {
1270
+ return this._localRedactionEvent.status;
1271
+ }
1272
+ return this.status;
1273
+ }
1274
+ getServerAggregatedRelation(relType) {
1275
+ var _this$getUnsigned$mR;
1276
+ return (_this$getUnsigned$mR = this.getUnsigned()["m.relations"]) === null || _this$getUnsigned$mR === void 0 ? void 0 : _this$getUnsigned$mR[relType];
1277
+ }
1278
+
1279
+ /**
1280
+ * Returns the event ID of the event replacing the content of this event, if any.
1281
+ */
1282
+ replacingEventId() {
1283
+ var replaceRelation = this.getServerAggregatedRelation(RelationType.Replace);
1284
+ if (replaceRelation) {
1285
+ return replaceRelation.event_id;
1286
+ } else if (this._replacingEvent) {
1287
+ return this._replacingEvent.getId();
1288
+ }
1289
+ }
1290
+
1291
+ /**
1292
+ * Returns the event replacing the content of this event, if any.
1293
+ * Replacements are aggregated on the server, so this would only
1294
+ * return an event in case it came down the sync, or for local echo of edits.
1295
+ */
1296
+ replacingEvent() {
1297
+ return this._replacingEvent;
1298
+ }
1299
+
1300
+ /**
1301
+ * Returns the origin_server_ts of the event replacing the content of this event, if any.
1302
+ */
1303
+ replacingEventDate() {
1304
+ var replaceRelation = this.getServerAggregatedRelation(RelationType.Replace);
1305
+ if (replaceRelation) {
1306
+ var ts = replaceRelation.origin_server_ts;
1307
+ if (Number.isFinite(ts)) {
1308
+ return new Date(ts);
1309
+ }
1310
+ } else if (this._replacingEvent) {
1311
+ var _this$_replacingEvent;
1312
+ return (_this$_replacingEvent = this._replacingEvent.getDate()) !== null && _this$_replacingEvent !== void 0 ? _this$_replacingEvent : undefined;
1313
+ }
1314
+ }
1315
+
1316
+ /**
1317
+ * Returns the event that wants to redact this event, but hasn't been sent yet.
1318
+ * @returns the event
1319
+ */
1320
+ localRedactionEvent() {
1321
+ return this._localRedactionEvent;
1322
+ }
1323
+
1324
+ /**
1325
+ * For relations and redactions, returns the event_id this event is referring to.
1326
+ */
1327
+ getAssociatedId() {
1328
+ var relation = this.getRelation();
1329
+ if (this.replyEventId) {
1330
+ return this.replyEventId;
1331
+ } else if (relation) {
1332
+ return relation.event_id;
1333
+ } else if (this.isRedaction()) {
1334
+ return this.event.redacts;
1335
+ }
1336
+ }
1337
+
1338
+ /**
1339
+ * Checks if this event is associated with another event. See `getAssociatedId`.
1340
+ */
1341
+ hasAssociation() {
1342
+ return !!this.getAssociatedId();
1343
+ }
1344
+
1345
+ /**
1346
+ * Update the related id with a new one.
1347
+ *
1348
+ * Used to replace a local id with remote one before sending
1349
+ * an event with a related id.
1350
+ *
1351
+ * @param eventId - the new event id
1352
+ */
1353
+ updateAssociatedId(eventId) {
1354
+ var relation = this.getRelation();
1355
+ if (relation) {
1356
+ relation.event_id = eventId;
1357
+ } else if (this.isRedaction()) {
1358
+ this.event.redacts = eventId;
1359
+ }
1360
+ }
1361
+
1362
+ /**
1363
+ * Flags an event as cancelled due to future conditions. For example, a verification
1364
+ * request event in the same sync transaction may be flagged as cancelled to warn
1365
+ * listeners that a cancellation event is coming down the same pipe shortly.
1366
+ * @param cancelled - Whether the event is to be cancelled or not.
1367
+ */
1368
+ flagCancelled() {
1369
+ var cancelled = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
1370
+ this._isCancelled = cancelled;
1371
+ }
1372
+
1373
+ /**
1374
+ * Gets whether or not the event is flagged as cancelled. See flagCancelled() for
1375
+ * more information.
1376
+ * @returns True if the event is cancelled, false otherwise.
1377
+ */
1378
+ isCancelled() {
1379
+ return this._isCancelled;
1380
+ }
1381
+
1382
+ /**
1383
+ * Get a copy/snapshot of this event. The returned copy will be loosely linked
1384
+ * back to this instance, though will have "frozen" event information. Other
1385
+ * properties of this MatrixEvent instance will be copied verbatim, which can
1386
+ * mean they are in reference to this instance despite being on the copy too.
1387
+ * The reference the snapshot uses does not change, however members aside from
1388
+ * the underlying event will not be deeply cloned, thus may be mutated internally.
1389
+ * For example, the sender profile will be copied over at snapshot time, and
1390
+ * the sender profile internally may mutate without notice to the consumer.
1391
+ *
1392
+ * This is meant to be used to snapshot the event details themselves, not the
1393
+ * features (such as sender) surrounding the event.
1394
+ * @returns A snapshot of this event.
1395
+ */
1396
+ toSnapshot() {
1397
+ var ev = new MatrixEvent(JSON.parse(JSON.stringify(this.event)));
1398
+ for (var [p, v] of Object.entries(this)) {
1399
+ if (p !== "event") {
1400
+ // exclude the thing we just cloned
1401
+ // @ts-ignore - XXX: this is just nasty
1402
+ ev[p] = v;
1403
+ }
1404
+ }
1405
+ return ev;
1406
+ }
1407
+
1408
+ /**
1409
+ * Determines if this event is equivalent to the given event. This only checks
1410
+ * the event object itself, not the other properties of the event. Intended for
1411
+ * use with toSnapshot() to identify events changing.
1412
+ * @param otherEvent - The other event to check against.
1413
+ * @returns True if the events are the same, false otherwise.
1414
+ */
1415
+ isEquivalentTo(otherEvent) {
1416
+ if (!otherEvent) return false;
1417
+ if (otherEvent === this) return true;
1418
+ var myProps = deepSortedObjectEntries(this.event);
1419
+ var theirProps = deepSortedObjectEntries(otherEvent.event);
1420
+ return JSON.stringify(myProps) === JSON.stringify(theirProps);
1421
+ }
1422
+
1423
+ /**
1424
+ * Summarise the event as JSON.
1425
+ *
1426
+ * If encrypted, include both the decrypted and encrypted view of the event.
1427
+ *
1428
+ * This is named `toJSON` for use with `JSON.stringify` which checks objects
1429
+ * for functions named `toJSON` and will call them to customise the output
1430
+ * if they are defined.
1431
+ *
1432
+ * **WARNING** Do not log the result of this method; otherwise, it will end up
1433
+ * in rageshakes, leading to a privacy violation.
1434
+ *
1435
+ * @deprecated Prefer to use {@link MatrixEvent#getEffectiveEvent} or similar.
1436
+ * This method will be removed soon; it is too easy to use it accidentally
1437
+ * and cause a privacy violation (cf https://github.com/vector-im/element-web/issues/26380).
1438
+ * In any case, the value it returns is not a faithful serialization of the object.
1439
+ */
1440
+ toJSON() {
1441
+ var event = this.getEffectiveEvent();
1442
+ if (!this.isEncrypted()) {
1443
+ return event;
1444
+ }
1445
+ return {
1446
+ decrypted: event,
1447
+ encrypted: this.event
1448
+ };
1449
+ }
1450
+ setVerificationRequest(request) {
1451
+ this.verificationRequest = request;
1452
+ }
1453
+ setTxnId(txnId) {
1454
+ this.txnId = txnId;
1455
+ }
1456
+ getTxnId() {
1457
+ return this.txnId;
1458
+ }
1459
+
1460
+ /**
1461
+ * Set the instance of a thread associated with the current event
1462
+ * @param thread - the thread
1463
+ */
1464
+ setThread(thread) {
1465
+ // don't allow state events to be threaded as per the spec
1466
+ if (this.isState()) {
1467
+ return;
1468
+ }
1469
+ if (this.thread) {
1470
+ this.reEmitter.stopReEmitting(this.thread, [ThreadEvent.Update]);
1471
+ }
1472
+ this.thread = thread;
1473
+ this.setThreadId(thread === null || thread === void 0 ? void 0 : thread.id);
1474
+ if (thread) {
1475
+ this.reEmitter.reEmit(thread, [ThreadEvent.Update]);
1476
+ }
1477
+ }
1478
+
1479
+ /**
1480
+ * Get the instance of the thread associated with the current event
1481
+ */
1482
+ getThread() {
1483
+ return this.thread;
1484
+ }
1485
+ setThreadId(threadId) {
1486
+ this.threadId = threadId;
1487
+ }
1488
+ }
1489
+
1490
+ /* REDACT_KEEP_KEYS gives the keys we keep when an event is redacted
1491
+ *
1492
+ * This is specified here:
1493
+ * http://matrix.org/speculator/spec/HEAD/client_server/latest.html#redactions
1494
+ *
1495
+ * Also:
1496
+ * - We keep 'unsigned' since that is created by the local server
1497
+ * - We keep user_id for backwards-compat with v1
1498
+ */
1499
+ var REDACT_KEEP_KEYS = new Set(["event_id", "type", "room_id", "user_id", "sender", "state_key", "prev_state", "content", "unsigned", "origin_server_ts"]);
1500
+
1501
+ // a map from state event type to the .content keys we keep when an event is redacted
1502
+ var REDACT_KEEP_CONTENT_MAP = {
1503
+ [EventType.RoomMember]: {
1504
+ membership: 1
1505
+ },
1506
+ [EventType.RoomJoinRules]: {
1507
+ join_rule: 1
1508
+ },
1509
+ [EventType.RoomPowerLevels]: {
1510
+ ban: 1,
1511
+ events: 1,
1512
+ events_default: 1,
1513
+ kick: 1,
1514
+ redact: 1,
1515
+ state_default: 1,
1516
+ users: 1,
1517
+ users_default: 1
1518
+ }
1519
+ };
1520
+ //# sourceMappingURL=event.js.map